前提条件:
1.安装K8S,参考:使用kubeadm安装kubernetes_v1.18.x
2.安装了NFS服务器:参考: 搭建NFS Server
- 配置好docker本地私有仓库,假设当前的docker私仓地址为192.168.10.240:8050
# 可直接通过 docker-compose 创建一个本地私有仓库
# 将此文件命名为 registry.yaml 运行 docker-compose -f registry.yaml up 启动
# 启动完成后,将生成的auth/passwd文件内容改成如下文本,去掉#号,即声明账号和密码为 docker 和 123456
# docker:$2y$05$9lG7QFC/hSCj/s.c4769K.4mSsqWF5OwTPv2UP6.itFGlWCV/HwVS
version: '2.1'
services:
registry:
image: registry
container_name: my_registry
volumes:
- ./registry:/var/lib/registry
- ./auth:/auth
environment:
- REGISTRY_AUTH=htpasswd
- REGISTRY_AUTH_HTPASSWD_REALM=Registry_Realm
- REGISTRY_AUTH_HTPASSWD_PATH=/auth/passwd
restart: always
privileged: true
ports:
- "8050:5000"
然后将私仓的地址配置到docker的daemon配置文件中.Linux环境叫daemon.json,docker安装后默认没有daemon.json这个配置文件,需要进行手动创建。配置文件的默认路径:/etc/docker/daemon.json。windows配置如下:
image.png
- 下载demo应用程序JAR包 链接:https://pan.baidu.com/s/1eG1qXjPhOYqK80k65LX8Aw
提取码:kmcb - 下载相关配置文件,https://github.com/sun449036002/k8s-springboot-springcloud-consul.git,并把之前下载的两个jar包,复制到此项目中的根目录(k8s-springboot-springcloud-consul目录)
打包镜像并上传到本地私有仓库
- 先登录本地仓库,按提示输入账号和密码
docker login 192.168.10.240:8050
- 在根目录,根据Dockerfile build 镜像,打上标签并push到私有仓库, 注意build时末尾的点号
docker build -t shop-api .
docker tag shop-api 192.168.10.240:8050/sym/shop-api
docker push 192.168.10.240:8050/sym/shop-api
docker build -t shop-user-center -f Dockerfile4UserCenter .
docker tag shop-user-center 192.168.10.240:8050/sym/shop-user-center
docker push 192.168.10.240:8050/sym/shop-user-center
- 创建k8s中docker pull 时需要使用到的认证名称,账号密码换成自己的搭建时设置的值
kubectl create secret docker-registry regsecret --docker-server=192.168.10.240:8050 --docker-username=docker --docker-password=123456 --docker-email=5566@qq.com
k8s.yaml配置文件描述:
- user api 配置说明: image.png
-
mysql、redis 配置说明
mysql的数据内容直接映射到主机的本地硬盘中 image.png
mysql的配置文件通过将数据映射到挂载在本地的NFS对应的目录中,
程序中通过K8S配置的Service名称来连接mysql,故这里的服务名称不能变,同理,redis类似。
image.png
image.png - consul 配置说明 image.png
启动应用
进入到 k8s-springboot-springcloud-consul目录,执行启动各服务
kubectl apply -f k8s.yaml
执行后,查看运行状态,
kubectl get svc,pod -o wide
image.png
通过上面的端口加本机IP访问 consul后台UI界面
image.png
若都是Running说明启动成功, 若有没有在Running状态的,可执行以下命令查看错误原因及日志
kubectl describe pod/user-api-55f444446c-mmlf6
image.png
# 或者查看 pod中的日志,看是否有具体的报错信息
kubectl logs pod/user-api-55f444446c-mmlf6
image.png
当查看 pod/user-center-xxxxx的log日志时,发现shop数据库没有创建时,可通过mysql工具连接到mysql,创建名为shop的数据,并导入项目根目录中sql.sql中的数据,
# 连接数据的信息
host: 127.0.0.1
port: 31233
user:root
password:123456
并重启pod即可,通过kubuctl delete 删除pod,使控制器自动启动一个新的pod
#删除容器,使之重启一个
kubectl delete pod/user-center-xxxxxx
后续数据准备,并验证接口
- 先通过映射出来的端口,连接redis 并往redis插入一条数据token对应的openid oIBgo45C6N1kW8u2ZF1,假如指定token为abvdefg
# 连接redis信息
# host: 127.0.0.1
# port: 31238
# password:123456
SET user:openid:abvdefg "oIBgo45C6N1kW8u2ZF1"
- postman post 请求updateuserinfo接口存入redis,或者直接命令行中curl请求
curl --location --request POST 'http://127.0.0.1:31234/updateInfo?token=abvdefg' \
--form 'nickName=abc' \
--form 'avatarUrl=abc123456789' \
--form 'city=上海' \
--form 'gener=1' \
--form 'country=中国' \
--form 'province=上海' \
--form 'language=1'
image.png
3.最后访问接口查看是否正常获取到用户信息
http://127.0.0.1:31234/user/detail?token=abvdefg
网友评论