这节咱们开始开发用户服务,上次通过python开发的信息服务已经开发完毕。源码:https://github.com/limingios/msA-docker
用户服务的分析
用户服务使用java语言进行开发,对外通过thift的接口,依赖于下面的信息服务,后端有数据库,开发一个服务,首选需要设计对外的接口,都给别人提供什么样的服务。
用户服务接口创建
- pom编辑
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>ms-server</artifactId>
<groupId>com.idig8</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<groupId>com.idig8</groupId>
<artifactId>user-thrift-service-api</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>org.apache.thrift</groupId>
<artifactId>libthrift</artifactId>
<version>0.10.0</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
- 创建对应这个接口提供服务的thrift
namespace java com.idig8.thrift.user
struct UserInfo{
1:i32 id,
2:string username,
3:string password,
4:string realName,
5:string mobile,
6:string email
}
service UserService{
UserInfo getUserById(1:i32 id)
UserInfo getUserByName(1:string username);
void regiserUser(1:UserInfo userInfo);
}
- 命令生成java对应的接口类
thrift --gen java -out ../src/main/java user-service.thrift
没有建立环境变量,直接在目录下生成的,然后拷贝到对应的目录下。
- 生成2个类,一个是实体类,一个对应的user-service( 这都是通过thrift自动生成的)
因自动生成源码太多,直接看文章头的连接地址下载吧
- 实现user-thrift-serive-api的接口
- 推荐大家使用docker的方式安装mysql,之前我的中级有在windows、mac环境下安装docker的方式
# mac下
cur_dir = 'pwd'
docker stop idig8-mysql
docker rm idig8-mysql
docker run --name idig8-mysql -v ${cur_dir}/conf:/etc/mysql/conf.d -v ${cur_dir}/data:/var/lib/mysql -p 3306:3306 -e MY_ROOT_PASSWORD=root -d mysql:latest
这里我直接使用公网的一个ip地址来远程访问,新建数据库表
- user-thrift-service 使用springboot的方式
这些都是springboot的基本操作,建议看我的源码吧。
PS:老铁可能感觉很乱,我把思路从头到尾说一下
- 编写thrift的文件
- 建立一个api接口,也就是user-thrift-service-api,通过thrift生成对应的java类
- 建立user-thrift-service,通过pom引用user-thrift-service-api的jar包文件。
- user-thrift-service 里面建立service,实现里面user-thrift-service-api的jar包接口方法。
- 通过引入mybatise 实现数据库调用dao,service引入dao,完成接口
- ThriftServer 引入的接口方法,启动服务代码,实现RPC开通properties里面的端口配置