第14章:部署Java网站项目案例
1 说明
(1) 项目迁移到k8s平台的流程
1) 制作镜像
dockerfile、docker+jenkins持续集成。镜像分类:基础镜像、中间镜像、项目镜像
2) 控制器管理pod
控制器管理pod,deployment(无状态应用)、deamonset(守护进程)、statsfulset(有状态应用)、job&cronjob(批处理)
3) pod数据持久化
pv、pvc
4) 暴露应用
5) 对外发布应用
service nodeport、ingress(LB -> ingress controller -> pod)
2 环境说明
主机名称 | ip地址 | 备注 |
---|---|---|
k8s_harbor | 172.16.1.61 | 访问:http://172.16.1.61/ 用户:admin 密码:Harbor12345 项目:java(包含tomcat:v01的镜像) |
k8s_gitlab | 172.16.1.62 | 访问:http://172.16.1.62:9999/ 用户:root 密码:12345678 项目:dev/java |
k8s_nfs | 172.16.1.63 | 用于镜像构建和镜像推送和nfs |
3 操作步骤
(1) 安装编译环境
1) 安装openjdk和maven
[root@k8s_nfs ~]# yum install java-1.8.0-openjdk maven -y 2) 替换maven国内源
[root@k8s_nfs ~]# vim /etc/maven/settings.xml
# 158行下面插入如下内容
<mirror>
<id>aliyunmaven</id>
<mirrorOf>*</mirrorOf>
<name>阿里云公共仓库</name>
<url>https://maven.aliyun.com/repository/public</url>
</mirror> (2) 编译构建
[root@k8s_nfs ~]# git clone http://172.16.1.62:9999/dev/java.git
[root@k8s_nfs ~]# cd java/
[root@k8s_nfs java]# mvn clean package -DskipTests=true
[root@k8s_nfs java]# ls target/
classes ly-simple-tomcat-0.0.1-SNAPSHOT maven-archiver
generated-sources ly-simple-tomcat-0.0.1-SNAPSHOT.war maven-status (3) 使用Dockerfile构建镜像并将war包推送到镜像仓库
1) 修改harbor镜像仓库认证(需要在k8s集群上也要做配置,否则无法拉取)
[root@k8s_nfs java]# cat /etc/docker/daemon.json
{
"registry-mirrors": ["https://b1cx9cn7.mirror.aliyuncs.com"],
"insecure-registries": ["172.16.1.61"]
} [root@k8s_nfs java]# systemctl daemon-reload
[root@k8s_nfs java]# systemctl restart docker 2) 登录镜像仓库
[root@k8s_nfs java]# docker login 172.16.1.61 3) 将war包打入tomcat镜像
[root@k8s_nfs java]# cat Dockerfile
FROM 172.16.1.61/java/tomcat:v01
RUN rm -rf /usr/local/tomcat/webapps/*
COPY target/*.war /usr/local/tomcat/webapps/ROOT.war [root@k8s_nfs java]# docker build -t 172.16.1.61/java/tomcat:v20 . [root@k8s_nfs java]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
172.16.1.61/java/tomcat v20 36330bfb480e 9 seconds ago 785MB
172.16.1.61/java/tomcat v01 fc492f3c2b01 23 hours ago 767MB 4) 推送tomcat项目镜像到harbor仓库
[root@k8s_nfs java]# docker push 172.16.1.61/java/tomcat:v20 (4) 创建secret保存harbor认证信息
[root@k8s-admin ~]# kubectl create secret docker-registry dockerpullauth --docker-username=admin --docker-password=Harbor12345 --docker-server=172.16.1.61 (5) 编写yaml部署(deployment)
[root@k8s-admin ~]# kubectl create deployment java --image=172.16.1.61/java/tomcat:v20 --dry-run -o yaml > deplo
yment-java.yaml [root@k8s-admin ~]# cat deployment-java.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: java
labels:
app: java
spec:
replicas: 3
selector:
matchLabels:
project: www
app: java
template:
metadata:
labels:
project: www
app: java
spec:
imagePullSecrets:
- name: "dockerpullauth"
restartPolicy: Always
containers:
- image: 172.16.1.61/java/tomcat:v20
name: tomcat
imagePullPolicy: IfNotPresent
ports:
- containerPort: 8080
name: tomcat
protocol: TCP
resources:
requests:
cpu: 0.5
memory: 1Gi
limits:
cpu: 1
memory: 2Gi
livenessProbe:
httpGet:
path: /
port: 8080
initialDelaySeconds: 60
timeoutSeconds: 20
periodSeconds: 10
readinessProbe:
httpGet:
path: /
port: 8080
initialDelaySeconds: 60
periodSeconds: 10
timeoutSeconds: 20 [root@k8s-admin ~]# kubectl apply -f deployment-java.yaml
[root@k8s-admin ~]# kubectl get pod -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
java-7f9c5f9d64-8n675 1/1 Running 0 9m26s 10.244.1.14 k8s-node1 <none> <none>
java-7f9c5f9d64-tnrft 1/1 Running 0 9m26s 10.244.2.13 k8s-node2 <none> <none>
java-7f9c5f9d64-xntk9 1/1 Running 0 9m26s 10.244.2.12 k8s-node2 <none> <none> (6) 编写yaml部署(service)
[root@k8s-admin ~]# kubectl expose deployment java --port=80 --target-port=8080 --type=NodePort --dry-run -o yaml > service-java.yaml [root@k8s-admin ~]# cat service-java.yaml
apiVersion: v1
kind: Service
metadata:
labels:
app: java
name: java
spec:
ports:
- port: 80
protocol: TCP
targetPort: 8080
nodePort: 30009
selector:
app: java
project: www
type: NodePort [root@k8s-admin ~]# kubectl apply -f service-java.yaml
[root@k8s-admin ~]# kubectl get deploy,pod,svc,ep -o wide
NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR
deployment.apps/java 3/3 3 3 30m tomcat 172.16.1.61/java/tomcat:v20 app=java,project=www NAME READY STATUS RESTARTS AGE IP NODE
pod/java-7f9c5f9d64-8n675 1/1 Running 0 30m 10.244.1.14 k8s-node1
pod/java-7f9c5f9d64-tnrft 1/1 Running 0 30m 10.244.2.13 k8s-node2
pod/java-7f9c5f9d64-xntk9 1/1 Running 0 30m 10.244.2.12 k8s-node2 NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE SELECTOR
service/java NodePort 10.96.192.44 <none> 80:30009/TCP 2m53s app=java,project=www
service/kubernetes ClusterIP 10.96.0.1 <none> 443/TCP 44d <none> NAME ENDPOINTS AGE
endpoints/java 10.244.1.14:8080,10.244.2.12:8080,10.244.2.13:8080 2m53s
endpoints/kubernetes 172.16.1.70:6443 44d (7) 访问
http://172.16.1.71:30009/
http://172.16.1.72:30009/ (8) 创建数据库
[root@k8s_nfs ~]# docker run -d --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
[root@k8s_nfs ~]# docker exec -it mysql bash
root@d5503ea45b93:/# mysql -uroot -p$MYSQL_ROOT_PASSWORD
mysql> grant all on test.* to wp@'%' identified by '123456'; (9) 安装ingress-controller配置ingress.yaml模板实现对service下的pod做负载均衡,可以跳过k8s service的转发网络,直接负载service后面的pod提高效率。
第14章:部署Java网站项目案例的更多相关文章
- 部署Java Web项目报错(一)
今天,我在部署Java Web项目时,出现错误,并且在eclipse新建一个servers,却出现多个项目. 具体错误截图如下: 然后,我又将项目部署到JBoss服务器中,却还是运行不成功 22:12 ...
- 阿里云服务器部署Java Web项目全过程
最近需要将一个Java Web项目部署到服务器上,方便多人共享访问.这也是我第一次接触服务器之类的东西,也花了一点时间,最终总算部署成功,写下一篇文章记录以便日后回顾. 购买服务器 第一步当然是需要购 ...
- 阿里云部署Java web项目初体验(转)
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文主要讲了如何在阿里云上安装JDK.Tomcat以及其配置过程.最后以一个实例来演示在 ...
- 如何在tomcat中如何部署java EE项目
如何在tomcat中如何部署java EE项目 1.直接把项目复制到Tomcat安装目录的webapps目录中,这是最简单的一种Tomcat项目部署的方法,也是初学者最常用的方法.2.在tomcat安 ...
- 阿里云部署Java web项目初体验(转)/linux 上配置jdk和安装tomcat
摘要:本文主要讲了如何在阿里云上安装JDK.Tomcat以及其配置过程.最后以一个实例来演示在阿里云上部署Java web项目. 一.准备工作 购买了阿里云的云解析,和云服务器ecs. 2.下载put ...
- 在linux下用tomcat部署java web项目的过程与注意事项
在linux下用tomcat部署java web项目的过程与注意事项 一.安装JDK 到http://www.oracle.com/technetwork/java/javase/downloads/ ...
- 阿里云部署Java web项目
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文主要讲了如何在阿里云上安装JDK.Tomcat以及其配置过程.最后以一个实例来演示在 ...
- 新手小白Linux(Centos6.5)部署java web项目(总)
一.准备 1.linux centos版本的相关命令操作,千万别找ubuntu的,好多命令都不一样,新手小白我傻傻不知道硬是浪费了一天的时间……(百度百科linux版本了解一下) 2.远程登录: P ...
- 阿里云部署Java web项目初体验
林炳文Evankaka原创作品. 转载请注明出处http://blog.csdn.net/evankaka 摘要:本文主要讲了怎样在阿里云上安装JDK.Tomcat以及其配置过程. 最后以一个实例来演 ...
随机推荐
- 061.Python前端Django组件用户认证组件
一 auth认证组件 在使用pymysql,数据库迁移的时候.,默认生成有十张表如下 查看author_user表结构 mysql> desc auth_user; +------------- ...
- fcntl详解
功能描述:根据文件描述词来操作文件的特性. #include <unistd.h>#include <fcntl.h> int fcntl(int fd, int cmd); ...
- 8.2-3 partprobe、tune2fs
8.2 partprobe:更新内核的硬盘分区表信息 partprobe命令用于在硬盘分区发生改变时,更新Linux内核中的硬盘分区表数据.有时在使用fdisk.part命令对硬盘进行分区 ...
- 常用数据库连接池配置及使用(Day_11)
世上没有从天而降的英雄,只有挺身而出的凡人. --致敬,那些在疫情中为我们挺身而出的人. 运行环境 JDK8 + IntelliJ IDEA 2018.3 优点: 使用连接池的最主要的优点是性能.创 ...
- HTML中option的单页调用
我们在用到下拉列表框select时,需要对选中的<option>选项触发事件,其实<option>本身没有触发事件方法,我们只有在select里的 onchange方法里触发. ...
- bat脚本总结
1.修改密码 @echo off set /p b=请输入新密码: net user %username% %b% echo 密码修改成功 %b% 请牢记你的密码 pause 2.删除hosts文件并 ...
- 面部表情视频中进行远程心率测量:ICCV2019论文解析
面部表情视频中进行远程心率测量:ICCV2019论文解析 Remote Heart Rate Measurement from Highly Compressed Facial Videos: an ...
- OneFlow 并行特色
OneFlow 并行特色 在 Consistent 与 Mirrored 视角中,已经知道 OneFlow 提供了 mirrored 与 consistent 两种看待分布式系统的视角,并且提前知道了 ...
- Python基础_python的数据类型
一.Python 的标准数据类型 二.以下单个实际举例分析数据类型 2.1 python的数字类型 Int:整型,Python3 整型是没有限制大小的,可以当作 Long 类型使用,所以 Python ...
- Spring Cloud10:Zipkin 服务跟踪
一.概述 为什么要有服务跟踪,分布式系统中有很多个服务在相互调用,调用关系是错综复杂的,如果这时出现了问题,我们在进行问题排查的时候,或者在优化架构的时候,工作量就比较大,这时候就需要我们能够准确的跟 ...