2023-04-12 14:17:47 +08:00
|
|
|
|
<h1><center>利用kubernetes部署微服务项目</center></h1>
|
|
|
|
|
|
|
|
|
|
著作:行癫 <盗版必究>
|
|
|
|
|
|
|
|
|
|
------
|
|
|
|
|
|
|
|
|
|
## 一:环境准备
|
|
|
|
|
|
|
|
|
|
#### 1.kubernetes集群环境
|
|
|
|
|
|
|
|
|
|
集群环境检查
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master ~]# kubectl get node
|
|
|
|
|
NAME STATUS ROLES AGE VERSION
|
|
|
|
|
master Ready control-plane,master 11d v1.23.1
|
|
|
|
|
node-1 Ready <none> 11d v1.23.1
|
|
|
|
|
node-2 Ready <none> 11d v1.23.1
|
|
|
|
|
node-3 Ready <none> 11d v1.23.1
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 2.harbor环境
|
|
|
|
|
|
|
|
|
|
harbor环境检查
|
|
|
|
|
|
|
|
|
|
<img src="https://xingdian-image.oss-cn-beijing.aliyuncs.com/xingdian-image/image-20220508222722564.png" alt="image-20220508222722564" style="zoom:50%;" />
|
|
|
|
|
|
|
|
|
|
## 二:项目准备
|
|
|
|
|
|
|
|
|
|
#### 1.项目包
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#### 2.项目端口准备
|
|
|
|
|
|
|
|
|
|
| 服务 | 内部端口 | 外部端口 |
|
|
|
|
|
| :---------------------: | :------: | -------- |
|
|
|
|
|
| tensquare_eureka_server | 10086 | 30020 |
|
|
|
|
|
| tensquare_zuul | 10020 | 30021 |
|
|
|
|
|
| tensquare_admin_service | 9001 | 30024 |
|
|
|
|
|
| tensquare_gathering | 9002 | 30022 |
|
|
|
|
|
| mysql | 3306 | 30023 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## 三:项目部署
|
|
|
|
|
|
|
|
|
|
#### 1.eureka部署
|
|
|
|
|
|
|
|
|
|
application.yml文件修改
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
|
spring:
|
|
|
|
|
application:
|
|
|
|
|
name: EUREKA-HA
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
#单机配置
|
|
|
|
|
server:
|
|
|
|
|
port: 10086
|
|
|
|
|
|
|
|
|
|
eureka:
|
|
|
|
|
instance:
|
|
|
|
|
hostname: localhost
|
|
|
|
|
client:
|
|
|
|
|
register-with-eureka: false
|
|
|
|
|
fetch-registry: false
|
|
|
|
|
service-url:
|
|
|
|
|
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
|
|
|
|
|
#defaultZone: http://pod主机名称.service名称:端口/eureka/
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Dockerfile创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# ls
|
|
|
|
|
Dockerfile tensquare_eureka_server-1.0-SNAPSHOT.jar jdk-8u211-linux-x64.tar.gz
|
|
|
|
|
[root@nfs-harbor jdk]# cat Dockerfile
|
|
|
|
|
FROM xingdian
|
|
|
|
|
MAINTAINER "xingdian" <xingdian@gmail.com>
|
|
|
|
|
ADD jdk-8u211-linux-x64.tar.gz /usr/local/
|
|
|
|
|
RUN mv /usr/local/jdk1.8.0_211 /usr/local/java
|
|
|
|
|
ENV JAVA_HOME /usr/local/java/
|
|
|
|
|
ENV PATH $PATH:$JAVA_HOME/bin
|
|
|
|
|
COPY tensquare_eureka_server-1.0-SNAPSHOT.jar /usr/local
|
|
|
|
|
EXPOSE 10086
|
|
|
|
|
CMD java -jar /usr/local/tensquare_eureka_server-1.0-SNAPSHOT.jar
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
镜像构建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# docker build -t eureka:v2022.1 .
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
上传到镜像仓库:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# docker tag eureka:v2022.1 10.0.0.230/xingdian/eureka:v2022.1
|
|
|
|
|
[root@nfs-harbor jdk]# docker push 10.0.0.230/xingdian/eureka:v2022.1
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
仓库验证:
|
|
|
|
|
|
|
|
|
|
<img src="https://xingdian-image.oss-cn-beijing.aliyuncs.com/xingdian-image/image-20220508224930884.png" alt="image-20220508224930884" style="zoom:50%;" />
|
|
|
|
|
|
|
|
|
|
#### 2.tensquare_zuul部署
|
|
|
|
|
|
|
|
|
|
Dockerfile创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# cat Dockerfile
|
|
|
|
|
FROM xingdian
|
|
|
|
|
MAINTAINER "xingdian" <xingdian@gmail.com>
|
|
|
|
|
ADD jdk-8u211-linux-x64.tar.gz /usr/local/
|
|
|
|
|
RUN mv /usr/local/jdk1.8.0_211 /usr/local/java
|
|
|
|
|
ENV JAVA_HOME /usr/local/java/
|
|
|
|
|
ENV PATH $PATH:$JAVA_HOME/bin
|
|
|
|
|
COPY tensquare_zuul-1.0-SNAPSHOT.jar /usr/local
|
|
|
|
|
EXPOSE 10020
|
|
|
|
|
CMD java -jar /usr/local/tensquare_zuul-1.0-SNAPSHOT.jar
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
镜像构建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# docker build -t zuul:v2022.1 .
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
镜像上传:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# docker tag zuul:v2022.1 10.0.0.230/xingdian/zuul:v2022.1
|
|
|
|
|
[root@nfs-harbor jdk]# docker push 10.0.0.230/xingdian/zuul:v2022.1
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
仓库验证:
|
|
|
|
|
|
|
|
|
|
<img src="https://xingdian-image.oss-cn-beijing.aliyuncs.com/xingdian-image/image-20220508230055752.png" alt="image-20220508230055752" style="zoom:50%;" />
|
|
|
|
|
|
|
|
|
|
注意:
|
|
|
|
|
|
|
|
|
|
在构建之前使用vim修改源码jar包,修改的内容如下(文件:application.yml):
|
|
|
|
|
|
|
|
|
|
```yml
|
|
|
|
|
server:
|
|
|
|
|
port: 10020 # 端口
|
|
|
|
|
|
|
|
|
|
# 基本服务信息
|
|
|
|
|
spring:
|
|
|
|
|
application:
|
|
|
|
|
name: tensquare-zuul # 服务ID
|
|
|
|
|
|
|
|
|
|
# Eureka配置
|
|
|
|
|
eureka:
|
|
|
|
|
client:
|
|
|
|
|
service-url:
|
|
|
|
|
#defaultZone: http://192.168.66.103:10086/eureka,http://192.168.66.104:10086/eureka # Eureka访问地址
|
|
|
|
|
#tensquare_eureka_server地址和端口(修改)
|
|
|
|
|
defaultZone: http://10.0.0.220:30020/eureka
|
|
|
|
|
instance:
|
|
|
|
|
prefer-ip-address: true
|
|
|
|
|
|
|
|
|
|
# 修改ribbon的超时时间
|
|
|
|
|
ribbon:
|
|
|
|
|
ConnectTimeout: 1500 # 连接超时时间,默认500ms
|
|
|
|
|
ReadTimeout: 3000 # 请求超时时间,默认1000ms
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 修改hystrix的熔断超时时间
|
|
|
|
|
hystrix:
|
|
|
|
|
command:
|
|
|
|
|
default:
|
|
|
|
|
execution:
|
|
|
|
|
isolation:
|
|
|
|
|
thread:
|
|
|
|
|
timeoutInMillisecond: 2000 # 熔断超时时长,默认1000ms
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 网关路由配置
|
|
|
|
|
zuul:
|
|
|
|
|
routes:
|
|
|
|
|
admin:
|
|
|
|
|
path: /admin/**
|
|
|
|
|
serviceId: tensquare-admin-service
|
|
|
|
|
gathering:
|
|
|
|
|
path: /gathering/**
|
|
|
|
|
serviceId: tensquare-gathering
|
|
|
|
|
|
|
|
|
|
# jwt参数
|
|
|
|
|
jwt:
|
|
|
|
|
config:
|
|
|
|
|
key: itcast
|
|
|
|
|
ttl: 1800000
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 3.mysql部署
|
|
|
|
|
|
|
|
|
|
镜像获取(使用官方镜像):
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor mysql]# docker pull mysql:5.7.38
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
镜像上传:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor mysql]# docker tag mysql:5.7.38 10.0.0.230/xingdian/mysql:v1
|
|
|
|
|
[root@nfs-harbor mysql]# docker push 10.0.0.230/xingdian/mysql:v1
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 4.admin_service部署
|
|
|
|
|
|
|
|
|
|
Dockerfile创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# cat Dockerfile
|
|
|
|
|
FROM xingdian
|
|
|
|
|
MAINTAINER "xingdian" <xingdian@gmail.com>
|
|
|
|
|
ADD jdk-8u211-linux-x64.tar.gz /usr/local/
|
|
|
|
|
RUN mv /usr/local/jdk1.8.0_211 /usr/local/java
|
|
|
|
|
ENV JAVA_HOME /usr/local/java/
|
|
|
|
|
ENV PATH $PATH:$JAVA_HOME/bin
|
|
|
|
|
COPY tensquare_admin_service-1.0-SNAPSHOT.jar /usr/local
|
|
|
|
|
EXPOSE 9001
|
|
|
|
|
CMD java -jar /usr/local/tensquare_admin_service-1.0-SNAPSHOT.jar
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
镜像构建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# docker build -t admin_service:v2022.1 .
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
镜像上传:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# docker tag admin_service:v2022.1 10.0.0.230/xingdian/admin_service:v2022.1
|
|
|
|
|
[root@nfs-harbor jdk]# docker push 10.0.0.230/xingdian/admin_service:v2022.1
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
注意:
|
|
|
|
|
|
|
|
|
|
在构建之前使用vim修改源码jar包,修改的内容如下(文件:application.yml):
|
|
|
|
|
|
|
|
|
|
```yml
|
|
|
|
|
spring:
|
|
|
|
|
application:
|
|
|
|
|
name: tensquare-admin-service #指定服务名
|
|
|
|
|
datasource:
|
|
|
|
|
driverClassName: com.mysql.jdbc.Driver
|
|
|
|
|
#数据库地址(修改)
|
|
|
|
|
url: jdbc:mysql://10.0.0.220:30023/tensquare_user?characterEncoding=UTF8&useSSL=false
|
|
|
|
|
#数据库账户名(修改)
|
|
|
|
|
username: root
|
|
|
|
|
#数据库账户密码(修改)
|
|
|
|
|
password: mysql
|
|
|
|
|
jpa:
|
|
|
|
|
database: mysql
|
|
|
|
|
show-sql: true
|
|
|
|
|
|
|
|
|
|
#Eureka配置
|
|
|
|
|
eureka:
|
|
|
|
|
client:
|
|
|
|
|
service-url:
|
|
|
|
|
#defaultZone: http://192.168.66.103:10086/eureka,http://192.168.66.104:10086/eureka
|
|
|
|
|
##tensquare_eureka_server地址和端口(修改)
|
|
|
|
|
defaultZone: http://10.0.0.220:30020/eureka
|
|
|
|
|
instance:
|
|
|
|
|
lease-renewal-interval-in-seconds: 5 # 每隔5秒发送一次心跳
|
|
|
|
|
lease-expiration-duration-in-seconds: 10 # 10秒不发送就过期
|
|
|
|
|
prefer-ip-address: true
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# jwt参数
|
|
|
|
|
jwt:
|
|
|
|
|
config:
|
|
|
|
|
key: itcast
|
|
|
|
|
ttl: 1800000
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 5.gathering部署
|
|
|
|
|
|
|
|
|
|
Dockerfile创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# cat Dockerfile
|
|
|
|
|
FROM xingdian
|
|
|
|
|
MAINTAINER "xingdian" <xingdian@gmail.com>
|
|
|
|
|
ADD jdk-8u211-linux-x64.tar.gz /usr/local/
|
|
|
|
|
RUN mv /usr/local/jdk1.8.0_211 /usr/local/java
|
|
|
|
|
ENV JAVA_HOME /usr/local/java/
|
|
|
|
|
ENV PATH $PATH:$JAVA_HOME/bin
|
|
|
|
|
COPY tensquare_gathering-1.0-SNAPSHOT.jar /usr/local
|
|
|
|
|
CMD java -jar /usr/local/tensquare_gathering-1.0-SNAPSHOT.jar
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
镜像构建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# docker build -t gathering:v2022.1 .
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
镜像上传:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor jdk]# docker tag gathering:v2022.1 10.0.0.230/xingdian/gathering:v2022.1
|
|
|
|
|
[root@nfs-harbor jdk]# docker push 10.0.0.230/xingdian/gathering:v2022.1
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
仓库验证:
|
|
|
|
|
|
|
|
|
|
<img src="https://xingdian-image.oss-cn-beijing.aliyuncs.com/xingdian-image/image-20220508233621370.png" alt="image-20220508233621370" style="zoom:50%;" />
|
|
|
|
|
|
|
|
|
|
注意:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
```yml
|
|
|
|
|
server:
|
|
|
|
|
port: 9002
|
|
|
|
|
spring:
|
|
|
|
|
application:
|
|
|
|
|
name: tensquare-gathering #指定服务名
|
|
|
|
|
datasource:
|
|
|
|
|
driverClassName: com.mysql.jdbc.Driver
|
|
|
|
|
#数据库地址(修改)
|
|
|
|
|
url: jdbc:mysql://10.0.0.220:30023/tensquare_gathering?characterEncoding=UTF8&useSSL=false
|
|
|
|
|
#数据库地址(修改)
|
|
|
|
|
username: root
|
|
|
|
|
#数据库账户密码(修改)
|
|
|
|
|
password: mysql
|
|
|
|
|
jpa:
|
|
|
|
|
database: mysql
|
|
|
|
|
show-sql: true
|
|
|
|
|
#Eureka客户端配置
|
|
|
|
|
eureka:
|
|
|
|
|
client:
|
|
|
|
|
service-url:
|
|
|
|
|
#defaultZone: http://192.168.66.103:10086/eureka,http://192.168.66.104:10086/eureka
|
|
|
|
|
#tensquare_eureka_server地址和端口(修改)
|
|
|
|
|
defaultZone: http://10.0.0.220:30020/eureka
|
|
|
|
|
instance:
|
|
|
|
|
lease-renewal-interval-in-seconds: 5 # 每隔5秒发送一次心跳
|
|
|
|
|
lease-expiration-duration-in-seconds: 10 # 10秒不发送就过期
|
|
|
|
|
prefer-ip-address: true
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## 四:kubernetes集群部署
|
|
|
|
|
|
|
|
|
|
#### 1.所有镜像验证
|
|
|
|
|
|
|
|
|
|
![image-20220508233955412](https://xingdian-image.oss-cn-beijing.aliyuncs.com/xingdian-image/image-20220508233955412.png)
|
|
|
|
|
#### 2.部署eureka
|
|
|
|
|
|
|
|
|
|
Eureka之Deployment创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# cat Eureka.yaml
|
|
|
|
|
apiVersion: apps/v1
|
|
|
|
|
kind: Deployment
|
|
|
|
|
metadata:
|
|
|
|
|
name: eureka-deployment
|
|
|
|
|
labels:
|
|
|
|
|
app: eureka
|
|
|
|
|
spec:
|
|
|
|
|
replicas: 1
|
|
|
|
|
selector:
|
|
|
|
|
matchLabels:
|
|
|
|
|
app: eureka
|
|
|
|
|
template:
|
|
|
|
|
metadata:
|
|
|
|
|
labels:
|
|
|
|
|
app: eureka
|
|
|
|
|
spec:
|
|
|
|
|
containers:
|
|
|
|
|
- name: nginx
|
|
|
|
|
image: 10.0.0.230/xingdian/eureka:v2022.1
|
|
|
|
|
ports:
|
|
|
|
|
- containerPort: 10086
|
|
|
|
|
---
|
|
|
|
|
apiVersion: v1
|
|
|
|
|
kind: Service
|
|
|
|
|
metadata:
|
|
|
|
|
name: eureka-service
|
|
|
|
|
labels:
|
|
|
|
|
app: eureka
|
|
|
|
|
spec:
|
|
|
|
|
type: NodePort
|
|
|
|
|
ports:
|
|
|
|
|
- port: 10086
|
|
|
|
|
name: eureka
|
|
|
|
|
targetPort: 10086
|
|
|
|
|
nodePort: 30020
|
|
|
|
|
selector:
|
|
|
|
|
app: eureka
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# kubectl create -f Eureka.yaml
|
|
|
|
|
deployment.apps/eureka-deployment created
|
|
|
|
|
service/eureka-service created
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
验证:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# kubectl get pod
|
|
|
|
|
NAME READY STATUS RESTARTS AGE
|
|
|
|
|
eureka-deployment-69c575d95-hx8s6 1/1 Running 0 2m20s
|
|
|
|
|
[root@master xingdian]# kubectl get svc
|
|
|
|
|
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
|
|
|
|
|
eureka-service NodePort 10.107.243.240 <none> 10086:30020/TCP 2m22s
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
<img src="https://xingdian-image.oss-cn-beijing.aliyuncs.com/xingdian-image/image-20220508235409218.png" alt="image-20220508235409218" style="zoom:50%;" />
|
|
|
|
|
|
|
|
|
|
#### 3.部署zuul
|
|
|
|
|
|
|
|
|
|
zuul之Deployment创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# cat Zuul.yaml
|
|
|
|
|
apiVersion: apps/v1
|
|
|
|
|
kind: Deployment
|
|
|
|
|
metadata:
|
|
|
|
|
name: zuul-deployment
|
|
|
|
|
labels:
|
|
|
|
|
app: zuul
|
|
|
|
|
spec:
|
|
|
|
|
replicas: 1
|
|
|
|
|
selector:
|
|
|
|
|
matchLabels:
|
|
|
|
|
app: zuul
|
|
|
|
|
template:
|
|
|
|
|
metadata:
|
|
|
|
|
labels:
|
|
|
|
|
app: zuul
|
|
|
|
|
spec:
|
|
|
|
|
containers:
|
|
|
|
|
- name: zuul
|
|
|
|
|
image: 10.0.0.230/xingdian/zuul:v2022.1
|
|
|
|
|
ports:
|
|
|
|
|
- containerPort: 10020
|
|
|
|
|
---
|
|
|
|
|
apiVersion: v1
|
|
|
|
|
kind: Service
|
|
|
|
|
metadata:
|
|
|
|
|
name: zuul-service
|
|
|
|
|
labels:
|
|
|
|
|
app: zuul
|
|
|
|
|
spec:
|
|
|
|
|
type: NodePort
|
|
|
|
|
ports:
|
|
|
|
|
- port: 10020
|
|
|
|
|
name: zuul
|
|
|
|
|
targetPort: 10086
|
|
|
|
|
nodePort: 30021
|
|
|
|
|
selector:
|
|
|
|
|
app: zuul
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# kubectl create -f Zuul.yaml
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
验证:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# kubectl get pod
|
|
|
|
|
NAME READY STATUS RESTARTS AGE
|
|
|
|
|
eureka-deployment-69c575d95-hx8s6 1/1 Running 0 7m42s
|
|
|
|
|
zuul-deployment-6d76647cf9-6rmdj 1/1 Running 0 10s
|
|
|
|
|
[root@master xingdian]# kubectl get svc
|
|
|
|
|
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
|
|
|
|
|
eureka-service NodePort 10.107.243.240 <none> 10086:30020/TCP 7m37s
|
|
|
|
|
kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 11d
|
|
|
|
|
zuul-service NodePort 10.103.35.255 <none> 10020:30021/TCP 5s
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
验证是否加入注册中心:
|
|
|
|
|
|
|
|
|
|
![image-20220508235634459](https://xingdian-image.oss-cn-beijing.aliyuncs.com/xingdian-image/image-20220508235634459.png)
|
|
|
|
|
|
|
|
|
|
#### 4.mysql部署
|
|
|
|
|
|
|
|
|
|
mysql之rc和svc创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master mysql]# cat mysql-svc.yaml
|
|
|
|
|
apiVersion: v1
|
|
|
|
|
kind: Service
|
|
|
|
|
metadata:
|
|
|
|
|
name: mysql-svc
|
|
|
|
|
labels:
|
|
|
|
|
name: mysql-svc
|
|
|
|
|
spec:
|
|
|
|
|
type: NodePort
|
|
|
|
|
ports:
|
|
|
|
|
- port: 3306
|
|
|
|
|
protocol: TCP
|
|
|
|
|
targetPort: 3306
|
|
|
|
|
name: http
|
|
|
|
|
nodePort: 30023
|
|
|
|
|
selector:
|
|
|
|
|
name: mysql-pod
|
|
|
|
|
[root@master mysql]# cat mysql-rc.yaml
|
|
|
|
|
apiVersion: v1
|
|
|
|
|
kind: ReplicationController
|
|
|
|
|
metadata:
|
|
|
|
|
name: mysql-rc
|
|
|
|
|
labels:
|
|
|
|
|
name: mysql-rc
|
|
|
|
|
spec:
|
|
|
|
|
replicas: 1
|
|
|
|
|
selector:
|
|
|
|
|
name: mysql-pod
|
|
|
|
|
template:
|
|
|
|
|
metadata:
|
|
|
|
|
labels:
|
|
|
|
|
name: mysql-pod
|
|
|
|
|
spec:
|
|
|
|
|
containers:
|
|
|
|
|
- name: mysql
|
|
|
|
|
image: 10.0.0.230/xingdian/mysql:v1
|
|
|
|
|
imagePullPolicy: IfNotPresent
|
|
|
|
|
ports:
|
|
|
|
|
- containerPort: 3306
|
|
|
|
|
env:
|
|
|
|
|
- name: MYSQL_ROOT_PASSWORD
|
|
|
|
|
value: "mysql"
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master mysql]# kubectl create -f mysql-rc.yaml
|
|
|
|
|
replicationcontroller/mysql-rc created
|
|
|
|
|
[root@master mysql]# kubectl create -f mysql-svc.yaml
|
|
|
|
|
service/mysql-svc created
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
验证:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master mysql]# kubectl get pod
|
|
|
|
|
NAME READY STATUS RESTARTS AGE
|
|
|
|
|
eureka-deployment-69c575d95-hx8s6 1/1 Running 0 29m
|
|
|
|
|
mysql-rc-sbdcl 1/1 Running 0 8m41s
|
|
|
|
|
zuul-deployment-6d76647cf9-gpsms 1/1 Running 0 21m
|
|
|
|
|
[root@master mysql]# kubectl get svc
|
|
|
|
|
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
|
|
|
|
|
eureka-service NodePort 10.107.243.240 <none> 10086:30020/TCP 29m
|
|
|
|
|
kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 11d
|
|
|
|
|
mysql-svc NodePort 10.98.4.62 <none> 3306:30023/TCP 9m1s
|
|
|
|
|
zuul-service NodePort 10.103.35.255 <none> 10020:30021/TCP 22m
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
数据库创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor ~]# mysql -u root -pmysql -h 10.0.0.220 -P 30023
|
|
|
|
|
Welcome to the MariaDB monitor. Commands end with ; or \g.
|
|
|
|
|
Your MySQL connection id is 2
|
|
|
|
|
Server version: 5.7.38 MySQL Community Server (GPL)
|
|
|
|
|
|
|
|
|
|
Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
|
|
|
|
|
|
|
|
|
|
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
|
|
|
|
|
|
|
|
|
|
MySQL [(none)]> create database tensquare_user charset=utf8;
|
|
|
|
|
Query OK, 1 row affected (0.00 sec)
|
|
|
|
|
|
|
|
|
|
MySQL [(none)]> create database tensquare_gathering charset=utf8;
|
|
|
|
|
Query OK, 1 row affected (0.01 sec)
|
|
|
|
|
|
|
|
|
|
MySQL [(none)]> exit
|
|
|
|
|
Bye
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
数据导入:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor ~]# mysql -u root -pmysql -h 10.0.0.220 -P 30023
|
|
|
|
|
Welcome to the MariaDB monitor. Commands end with ; or \g.
|
|
|
|
|
Your MySQL connection id is 3
|
|
|
|
|
Server version: 5.7.38 MySQL Community Server (GPL)
|
|
|
|
|
|
|
|
|
|
Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
|
|
|
|
|
|
|
|
|
|
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
|
|
|
|
|
|
|
|
|
|
MySQL [(none)]> source /var/ftp/share/tensquare_user.sql
|
|
|
|
|
|
|
|
|
|
MySQL [tensquare_user]> source /var/ftp/share/tensquare_gathering.sql
|
|
|
|
|
|
|
|
|
|
MySQL [tensquare_gathering]> exit
|
|
|
|
|
Bye
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
验证:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@nfs-harbor ~]# mysql -u root -pmysql -h 10.0.0.220 -P 30023
|
|
|
|
|
Welcome to the MariaDB monitor. Commands end with ; or \g.
|
|
|
|
|
Your MySQL connection id is 3
|
|
|
|
|
Server version: 5.7.38 MySQL Community Server (GPL)
|
|
|
|
|
|
|
|
|
|
Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
|
|
|
|
|
|
|
|
|
|
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
|
|
|
|
|
|
|
|
|
|
MySQL [(none)]> show databases;
|
|
|
|
|
+---------------------+
|
|
|
|
|
| Database |
|
|
|
|
|
+---------------------+
|
|
|
|
|
| information_schema |
|
|
|
|
|
| mysql |
|
|
|
|
|
| performance_schema |
|
|
|
|
|
| sys |
|
|
|
|
|
| tensquare_gathering |
|
|
|
|
|
| tensquare_user |
|
|
|
|
|
+---------------------+
|
|
|
|
|
6 rows in set (0.00 sec)
|
|
|
|
|
|
|
|
|
|
MySQL [(none)]> use tensquare_gathering
|
|
|
|
|
Reading table information for completion of table and column names
|
|
|
|
|
You can turn off this feature to get a quicker startup with -A
|
|
|
|
|
|
|
|
|
|
Database changed
|
|
|
|
|
MySQL [tensquare_gathering]> show tables;
|
|
|
|
|
+-------------------------------+
|
|
|
|
|
| Tables_in_tensquare_gathering |
|
|
|
|
|
+-------------------------------+
|
|
|
|
|
| tb_city |
|
|
|
|
|
| tb_gathering |
|
|
|
|
|
+-------------------------------+
|
|
|
|
|
2 rows in set (0.00 sec)
|
|
|
|
|
|
|
|
|
|
MySQL [tensquare_gathering]> use tensquare_user
|
|
|
|
|
Reading table information for completion of table and column names
|
|
|
|
|
You can turn off this feature to get a quicker startup with -A
|
|
|
|
|
|
|
|
|
|
Database changed
|
|
|
|
|
MySQL [tensquare_user]> show tables;
|
|
|
|
|
+--------------------------+
|
|
|
|
|
| Tables_in_tensquare_user |
|
|
|
|
|
+--------------------------+
|
|
|
|
|
| tb_admin |
|
|
|
|
|
+--------------------------+
|
|
|
|
|
1 row in set (0.01 sec)
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### 5.admin_service部署
|
|
|
|
|
|
|
|
|
|
admin_service之Deployment创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# cat Admin-service.yaml
|
|
|
|
|
apiVersion: apps/v1
|
|
|
|
|
kind: Deployment
|
|
|
|
|
metadata:
|
|
|
|
|
name: admin-deployment
|
|
|
|
|
labels:
|
|
|
|
|
app: admin
|
|
|
|
|
spec:
|
|
|
|
|
replicas: 1
|
|
|
|
|
selector:
|
|
|
|
|
matchLabels:
|
|
|
|
|
app: admin
|
|
|
|
|
template:
|
|
|
|
|
metadata:
|
|
|
|
|
labels:
|
|
|
|
|
app: admin
|
|
|
|
|
spec:
|
|
|
|
|
containers:
|
|
|
|
|
- name: admin
|
|
|
|
|
image: 10.0.0.230/xingdian/admin_service:v2022.1
|
|
|
|
|
ports:
|
|
|
|
|
- containerPort: 9001
|
|
|
|
|
---
|
|
|
|
|
apiVersion: v1
|
|
|
|
|
kind: Service
|
|
|
|
|
metadata:
|
|
|
|
|
name: admin-service
|
|
|
|
|
labels:
|
|
|
|
|
app: admin
|
|
|
|
|
spec:
|
|
|
|
|
type: NodePort
|
|
|
|
|
ports:
|
|
|
|
|
- port: 9001
|
|
|
|
|
name: admin
|
|
|
|
|
targetPort: 9001
|
|
|
|
|
nodePort: 30024
|
|
|
|
|
selector:
|
|
|
|
|
app: admin
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# kubectl create -f Admin-service.yaml
|
|
|
|
|
deployment.apps/admin-deployment created
|
|
|
|
|
service/admin-service created
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
验证:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# kubectl get pod
|
|
|
|
|
NAME READY STATUS RESTARTS AGE
|
|
|
|
|
admin-deployment-54c5664d69-l2lbc 1/1 Running 0 23s
|
|
|
|
|
eureka-deployment-69c575d95-mrj66 1/1 Running 0 47m
|
|
|
|
|
mysql-rc-zgxk4 1/1 Running 0 7m23s
|
|
|
|
|
zuul-deployment-6d76647cf9-gpsms 1/1 Running 0 39m
|
|
|
|
|
[root@master xingdian]# kubectl get svc
|
|
|
|
|
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
|
|
|
|
|
admin-service NodePort 10.101.251.47 <none> 9001:30024/TCP 6s
|
|
|
|
|
eureka-service NodePort 10.107.243.240 <none> 10086:30020/TCP 47m
|
|
|
|
|
kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 11d
|
|
|
|
|
mysql-svc NodePort 10.98.4.62 <none> 3306:30023/TCP 26m
|
|
|
|
|
zuul-service NodePort 10.103.35.255 <none> 10020:30021/TCP 39m
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
注册中心验证:
|
|
|
|
|
|
|
|
|
|
<img src="https://xingdian-image.oss-cn-beijing.aliyuncs.com/xingdian-image/image-20220509013257937.png" alt="image-20220509013257937" style="zoom:50%;" />
|
|
|
|
|
|
|
|
|
|
#### 6.gathering部署
|
|
|
|
|
|
|
|
|
|
gathering之Deployment创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# cat Gathering.yaml
|
|
|
|
|
apiVersion: apps/v1
|
|
|
|
|
kind: Deployment
|
|
|
|
|
metadata:
|
|
|
|
|
name: gathering-deployment
|
|
|
|
|
labels:
|
|
|
|
|
app: gathering
|
|
|
|
|
spec:
|
|
|
|
|
replicas: 1
|
|
|
|
|
selector:
|
|
|
|
|
matchLabels:
|
|
|
|
|
app: gathering
|
|
|
|
|
template:
|
|
|
|
|
metadata:
|
|
|
|
|
labels:
|
|
|
|
|
app: gathering
|
|
|
|
|
spec:
|
|
|
|
|
containers:
|
|
|
|
|
- name: nginx
|
|
|
|
|
image: 10.0.0.230/xingdian/gathering:v2022.1
|
|
|
|
|
ports:
|
|
|
|
|
- containerPort: 9002
|
|
|
|
|
---
|
|
|
|
|
apiVersion: v1
|
|
|
|
|
kind: Service
|
|
|
|
|
metadata:
|
|
|
|
|
name: gathering-service
|
|
|
|
|
labels:
|
|
|
|
|
app: gathering
|
|
|
|
|
spec:
|
|
|
|
|
type: NodePort
|
|
|
|
|
ports:
|
|
|
|
|
- port: 9002
|
|
|
|
|
name: gathering
|
|
|
|
|
targetPort: 9002
|
|
|
|
|
nodePort: 30022
|
|
|
|
|
selector:
|
|
|
|
|
app: gathering
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
创建:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# kubectl create -f Gathering.yaml
|
|
|
|
|
deployment.apps/gathering-deployment created
|
|
|
|
|
service/gathering-service created
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
验证:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
[root@master xingdian]# kubectl get pod
|
|
|
|
|
NAME READY STATUS RESTARTS AGE
|
|
|
|
|
admin-deployment-54c5664d69-2tqlw 1/1 Running 0 33s
|
|
|
|
|
eureka-deployment-69c575d95-xzx9t 1/1 Running 0 13m
|
|
|
|
|
gathering-deployment-6fcdd5d5-wbsxt 1/1 Running 0 27s
|
|
|
|
|
mysql-rc-zgxk4 1/1 Running 0 28m
|
|
|
|
|
zuul-deployment-6d76647cf9-jkm7f 1/1 Running 0 12m
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
注册中心验证:
|
|
|
|
|
|
|
|
|
|
<img src="https://xingdian-image.oss-cn-beijing.aliyuncs.com/xingdian-image/image-20220509005823566.png" alt="image-20220509005823566" style="zoom:50%;" />
|
|
|
|
|
|
|
|
|
|
#### 7.浏览器测试API接口
|
|
|
|
|
|
|
|
|
|
![image-20220509015035488](https://xingdian-image.oss-cn-beijing.aliyuncs.com/xingdian-image/image-20220509015035488.png)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|