本文主要记录linux上安装docker,docker部署springboot项目项目、redis、nginx等,以及容器间自定义网络的构建与使用。
一、相关资源
云服务器、linux系统。
二、步骤
1、重装系统
从0开始。。。 选择云服务器的系统.png这里我选择centos7.5的系统。
2、安装docker
此处介绍一下https://hub.docker.com/,上面有docker的入门介绍,也有各种镜像,包含官方认证的和用户自己上传的,每个镜像有使用步骤和介绍等。
linux安装docker相关介绍
// 获取get-docker.sh这个脚本
curl -fsSL https://get.docker.com -o get-docker.sh
// 运行脚本,脚本会自动检查当前系统,下载需要的东西
sudo sh get-docker.sh
运行结果.png
// 检查安装、查看docker版本
docker version
运行结果.png
// 重新加载配置文件、重启docker服务
systemctl daemon-reload
systemctl restart docker.service
3、下载、安装、运行nginx镜像
以nginx为例简单上手。
打开https://hub.docker.com/,搜索nginx,会出来一系列镜像,带OFFICIAL IMAGE的为官方认证的镜像。
//下载nginx:latest这个容器
docker pull nginx:latest
// 运行
docker run --name mynginx -d -p 8080:80 nginx:latest
--name 为容器起个名字
-d 后台运行容器,并返回容器id
-p 制定端口映射,格式: 宿主机端口:容器端口
nginx:latest:安装的nginx容器
下载并运行.png
访问8080端口
Welcome to nginx!.png
可以执行 docker inspect mynginx, 来查看mynginx的网络信息,其IP为系统自动分配的。
然而实际应用的时候我们需要指定IP,这就需要通过自定义网桥来实现。
4、创建自定义网桥
docker镜像直接启动的话会自动创建一个网桥,但是其IP是随机的,关于docker网络可参考此篇文章。因此,此处我们自定义一个网桥并指定其IP。
// 创建新的子网172.30.0.0
docker network create --subnet=172.30.0.0/16 new_bridge
// 查看docker的网络,见下图,其中NAME列中bridge、host、none均为docker自动创建的网络
docker network list
// 查看网桥元数据
docker network inspect new_bridge
new_bridge的元数据.png
5、安装redis
// 下载镜像
docker pull redis:latest
// 运行镜像,指定ip:172.30.0.3,并运行redis-server,同时配置appendonly yes
docker run --name myredis --network=new_bridge -d --ip 172.30.0.3 redis redis-server --appendonly yes
// 进入到容器内部,并执行 /bin/bash
docker exec -it myredis /bin/bash
// redis client
redis-cli
// 退出
exit
至此,redis就安装成功,下一步我们用docker启动springboot。
6、docker启动springboot项目
6.1 新建springboot项目并集成redis
redis地址配置为启动redis容器时候的ip。 配置redis.png@RestController
public class TempControler {
@Autowired
private RedisTemplate<String, String> redisTemplate;
@GetMapping("/set")
public String set(@RequestParam(name = "key") String key, @RequestParam(name = "value") String value) {
redisTemplate.opsForValue().set(key, value);
return key + " - " + value;
}
@GetMapping("/get")
public String get(@RequestParam(name = "key") String key) {
return redisTemplate.opsForValue().get(key);
}
@GetMapping("/test")
public String test() {
return "hello";
}
}
将工程打包得出demo-0.0.1-SNAPSHOT.jar,新建文件命名为Dockerfile,文件内容:
# Docker image for springboot file run
# VERSION 0.0.1
# Author: pibigstar
# 基础镜像使用java
FROM java:8
# VOLUME 指定了临时文件目录为/tmp。
# 其效果是在主机 /var/lib/docker 目录下创建了一个临时文件,并链接到容器的/tmp
VOLUME /tmp
# 将jar包添加到容器中并更名为app.jar
ADD demo-0.0.1-SNAPSHOT.jar app.jar
# 运行jar包
RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
6.2 将工程打包为镜像
服务器上新建docker文件夹,将jar包和Dockerfile,上传到docker文件夹里,执行:
// 给镜像起名demo,注意有个空格和点
docker build -t demo .
// 查看镜像,可以看到多出了一个名字叫demo的镜像
docker images
// 由于前面nginx已经把8080端口占用,因此我们先把nginx镜像启动的容器删除掉
docker rm -f mynginx
// 启动demo镜像
docker run --name demo --network=new_bridge -d -p 8080:8080 demo
6.3 测试
19.png
网友评论