sun449036002 / k8s-springboot-springcloud-consul

通过K8S+docker部署一个springboot+spring cloud项目
3 stars 1 forks source link

前提条件:

1.已经安装K8S,参考:https://kuboard.cn/install/install-k8s.html#%E7%A7%BB%E9%99%A4worker%E8%8A%82%E7%82%B9%E5%B9%B6%E9%87%8D%E8%AF%95

2.安装了NFS服务器:https://kuboard.cn/learning/k8s-intermediate/persistent/nfs.html#%E5%9C%A8kuboard%E4%B8%AD%E5%88%9B%E5%BB%BA-nfs-%E5%AD%98%E5%82%A8%E7%B1%BB

  1. 已配置好docker本地私有仓库,假设当前的docker私仓地址为192.168.10.240:8050
    # 可直接通过docker-compose -f registry.yaml up 创建一个本地私有仓库
    # 将此文件命名为 registry.yaml
    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"
  2. 下载demo应用程序JAR包 链接:https://pan.baidu.com/s/1eG1qXjPhOYqK80k65LX8Aw 提取码:kmcb
  3. 下载相关配置文件,https://github.com/sun449036002/k8s-springboot-springcloud-consul.git,并把之前下载的两个jar包,复制到此项目中的根目录(k8s-springboot-springcloud-consul目录)

打包镜像并上传到本地私有仓库

  1. 先登录本地仓库,按提示输入账号和密码
    docker login 192.168.10.240:8050 
  2. 在根目录,根据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

3. 创建k8s中docker pull 时需要使用到的认证名称,账号密码换成自己的搭建时设置的值
```sh
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配置文件描述:

  1. user api 配置说明:image.png

  2. mysql、redis 配置说明 mysql的配置文件通过将数据映射到挂载在本地的NFS对应的目录中, mysql的数据内容直接映射到主机的本地硬盘中image.png 程序中通过K8S配置的Service名称来连接mysql,故这里的服务名称不能变,同理,redis类似。 image.png image.png

  3. 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,导入根目录中的sql.sql中的数据,

# 连接数据的信息
host: 127.0.0.1
port: 31233
user:root
password:123456

并重启pod即可,通过kubuctl delete

#删除容器,使之重启一个
kubectl delete pod/user-center-xxxxxx

后续数据准备,并验证接口

  1. 先通过映射出来的端口,连接redis 并往redis插入一条数据token对应的openid oIBgo45C6N1kW8u2ZF1,假如指定token为abvdefg

    # 连接redis信息
    # host: 127.0.0.1
    # port: 31238
    # password:123456
    SET user:openid:abvdefg "oIBgo45C6N1kW8u2ZF1"
  2. 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=xxxxxxxx

本人学习时网上搜罗记录以此, 欢迎骚扰、留言、and 喷我

外加效果图:

image.png