注:默认已经安装好docker。
为什么要离线安装?
其实离线安装是建立在在线安装的基础上的;因为有可能我们的服务器由于安全问题无法访问外网,自此我们需要将镜像手动上传至服务器中。
所以现在的场景就是:我们手上有一台笔记本,可以上网;笔记本上可以远程连接到我们的服务器,而服务器无法连接外网。
1、需要在本地拉取所需镜像,但拉取镜像需要相关docker环境,故先安装相应工具。
在windows上安装Docker Community Edition for windows的参考链接:https://blog.csdn.net/MaxWoods/article/details/79774581
2、拉取所需镜像,并打成tar包
# 搜索有哪些镜像可以下载 docker search 镜像名 # 拉取镜像到本地 docker pull 镜像名 # 查看当前本机有哪些镜像 docker images # 打包 docker save -o 要打镜像包名称 镜像 示例:docker save -o nginx.tar nginx # tar包的保存路径为当前路径
DockerHub官网:https://hub.docker.com/
3、使用ftp将打包好的tar包上传到服务器中
4、加载镜像进入服务器中的docker容器;
当然服务器中的docker也需要手动安装,该安装过程请参考https://blog.csdn.net/qq_42511550/article/details/119188889
# 加载镜像;默认已经启动docker服务 docker load -i nginx.tar
5、查看镜像是否加载成功
docker image ls
6、进入相应文件夹创建yml文件(一般在app/nginx/docker-compose.yml文件夹下)
version: '3' services: nginx: container_name: nginx restart: always image: nginx ports: - 8080:80 - 80:80 - 443:443 volumes: - /data/nginx/conf.d:/etc/nginx/conf.d - /data/nginx/log:/var/log/nginx - /data/nginx/www:/var/www - /etc/letsencrypt:/etc/letsencrypt
7、根据yml文件中的数据卷volume创建相应文件夹(但好像若不手动创建其实也会自动被创建,就像/etc/letsencrypt目录一样)
mkdir /data/nginx/conf.d # 不要以为有后缀就是文件,此处的conf.d仍是一个文件夹
mkdir /data/nginx/log
8mkdir /data/nginx/www
8、进入/data/nginx/conf.d目录下创建一个default.conf文件
server{ listen 80; # 监听80端口 server_name localhost; # 请求的域名 location / { # 当请求进来后,映射上 / root /usr/share/nginx/html; # 将请求会映射到路径上. index index.html; # 默认请求会去寻找index.html作为欢迎页面. } }
9、启动nginx服务
docker-compose -f yml文件所在路径 up -d
10、进入nginx容器
docker exec -it nginx bash
11、查看nginx容器中端口开放情况
netstat -tlpn
12、测试端口映射连通性
telnet 宿主机IP 8080 # 端口映射为8080:80 表示宿主机的8080端口对应到nginx容器的80端口
13、web页面验证nginx服务
# 网页中输入
宿主机IP:8080
自此,nginx在docker中已经安装成功!
标签:安装,离线,nginx,镜像,docker,data,80 From: https://www.cnblogs.com/ReturnOfTheKing/p/17053279.html