1. Spring Data 项目
Spring Data 项目是 Spring 用来解决数据访问问题的解决方案,包含了大量的关系型数据库以及非关系型数据库的访问解决方案。它是一种简单且快速的数据访问技术
1.1 Spring Data 包含的主要的子项目:
- Spring Data Commons - Core Spring concepts underpinning every Spring Data project.
- Spring Data Gemfire - Provides easy configuration and access to GemFire from Spring applications.
- Spring Data JPA - Makes it easy to implement JPA-based repositories.
- Spring Data JDBC - JDBC-based repositories.
- Spring Data KeyValue - Map-based repositories and SPIs to easily build a Spring Data module for key-value stores.
- Spring Data LDAP - Provides Spring Data repository support for Spring LDAP.
- Spring Data MongoDB - Spring based, object-document support and repositories for MongoDB.
- Spring Data REST - Exports Spring Data repositories as hypermedia-driven RESTful resources.
- Spring Data Redis - Provides easy configuration and access to Redis from Spring applications.
- Spring Data for Apache Cassandra - Spring Data module for Apache Cassandra.
-
Spring Data for Apache Solr - Spring Data module for Apache Solr.
Spring Data 统一了 API 来对上述的数据存储技术进行数据访问操作提供了支持。通过核心 Spring Data Commons 项目来实现,它是各种 Spring Data 项目的依赖。
Spring Data Commons 数据访问根接口:
org.springframework.data.repository.Repository<T, ID extends Serializable>
Parameters:
<T> the domain type the repository manages 领域类
<ID> the type of the id of the entity the repository manages 领域类ID 类型作为类型参数
Repository 根接口的子接口:
org.springframework.data.repository.CrudRepository<T, ID extends Serializable>
该接口提供了数据的 CRUD 操作:
CrudRepository 的子接口:
org.springframework.data.repository.PagingAndSortingRepository<T, ID extends Serializable>
该接口定义了与分页和排序相关操作:
依赖以上的接口,不同的数据访问技术提供了不同的 Repository,如 Spring Data JPA 有 JpaRepository 、Spring Data MongoDB 有 MongoRepository.当然 Spring Data 项目还提供了一种 用户自定义Repository接口方式实现通过自定义属性名进行相关数据操作,例如:
public interface UserRepository extends Repository(User,Serializable)
2.引入Docker
Docker 是一个轻量级容器技术,类似于虚拟机技术。Docker 是直接运行在当前操作系统 Linux 之上,而不是运行在虚拟机中,但是也实现了虚拟机技术的资源隔离,性能远远高于虚拟机技术,目前各大主流云计算平台都支持Docker 容器技术,诸如:阿里云、百度云平台、Cloud Foundy 等,连微软会在下一个版本的 Window Server 及其云平台 Azure 上支持Docker. Docker 大有一统云计算的趋势。
2.1 Docker 安装、常用命令及参数
-
CentOS 安装命令:
启动 Docker: systemctl docker start
Docker 镜像检索
docker search redis下载镜像
docker pull redis-
查看镜像
docker images
REPOSITORY 表示 镜像名、 TAG 软件版本、 lastest 为最新版、IMAGE ID 是当前镜像的唯一标识、 CREATED 是当前镜像创建时间、 SIZE 表示镜像大小
镜像删除
docker rmi image-id 指定镜像标识删除
docker rmi $(docker images -q) 删除所有镜像-
Docker 容器命令:
运行镜像为容器的命令
docker run --name [自定义镜像容器名称] -d [镜像名]
诸如运行 redis 容器:
docker run --name rest-redis -d redis-
查看容器列表
docker ps
停止容器
docker stop [容器别名或者容器标识号]
docker stop rest-redis启动容器
docker start [容器别名或者容器标识号]
docker start rest-redis端口映射
Docker 容器中运行的软件所使用的端口,在本机和本机的局域网不能访问,所以要进行端口映射
docker run -d -p 本机端口:容器端口 --name [自定义镜像容器名称] [镜像名]
这个命令在后面部署软件的时候再聊删除容器
docker rm [容器别名或者容器标识号]删除所有容器
docker rm $(docker ps -a -q)容器日志
docker logs [容器别名或者容器标识号]登陆容器
docker exec -it [容器别名或者容器标识号] bash