docker部署nginx

1. 下载nginx

  1. [root@localhost my.Shells]# docker images
  2. REPOSITORY TAG IMAGE ID CREATED SIZE
  3. docker.io/redis latest 1e70071f4af4 6 weeks ago 106.7 MB
  4. [root@localhost my.Shells]# docker pull nginx //下载nginx
  5. Using default tag: latest
  6. Trying to pull repository docker.io/library/nginx ...
  7. latest: Pulling from docker.io/library/nginx
  8. e7bb522d92ff: Pull complete
  9. 6edc05228666: Pull complete
  10. cd866a17e81f: Pull complete
  11. Digest: sha256:285b49d42c703fdf257d1e2422765c4ba9d3e37768d6ea83d7fe2043dad6e63d
  12. [root@localhost my.Shells]# docker images
  13. REPOSITORY TAG IMAGE ID CREATED SIZE
  14. docker.io/nginx latest 3f8a4339aadd 3 weeks ago 108.5 MB
  15. docker.io/redis latest 1e70071f4af4 6 weeks ago 106.7 MB

2. 运行

  1. [root@localhost my.Shells]# docker run -p 8080:80 -d docker.io/nginx //将80端口映射为8080,或者80:80还是原先的80端口,不可以不写。
  2. c0462d5e18783e20f9515108fa62ab0f2ac808ea85370a7c82aee9407abf4672
  3. [root@localhost my.Shells]# netstat -anp | grep 8080 //端口已经开启了
  4. tcp6 0 0 :::8080 :::* LISTEN 2529/docker-proxy-c
  5. [root@localhost my.Shells]# docker ps //nginx已经在运行了
  6. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  7. c0462d5e1878 docker.io/nginx "nginx -g 'daemon off" 4 minutes ago Up 4 minutes 0.0.0.0:8080->80/tcp angry_mccarthy

3. 运行结果

  1. [root@localhost my.Shells]# ./openFirewallPort.sh //先在防火墙上开一个端口
  2. enter the port:
  3. 8080
  4. success
  5.  
  6. ---openFirewallPort.sh-------

echo "enter the port: "
 read port
 firewall-cmd --add-port=$port/tcp

  1. 下图已经成功访问到了

  1. 注意:
  2. docker运行nginx时,外界访问还是docker所在的那个IP地址,就相当于nginx在那台机器上运行一样。
  3. 但对于docker所在的那台机器来说,nginx就是附属于docker的一个镜像。若操作nginx还是由docker登录nginx容器,进行操作。
  4. 登录的nginx容器就是一个linux系统,只不过只有nginx而已,nginx按照linux默认路径安装。比如
  5. root@c0462d5e1878:/usr/share/nginx/html# ls 这个路径就是默认的静态页面存放路径
  6. 50x.html index.html
  7.  
  8. bash命令都一样,但是vi在我机器上是不能用的,但可以使用cpmv 等命令,因为nginx都是配置好的,不能乱改。
  9.  
  10. 1)可以通过在还未登录nignx容器前,把需要的文件写好,然后复制到指定目录下:
  11. [root@localhost my.Shells]# docker cp hello.html c0462d5e1878://usr/share/nginx/html
  12. [root@localhost my.Shells]# docker exec -it c0462d5e1878 bash
  13. root@c0462d5e1878:/usr/share/nginx/html# ls
  14. 50x.html hello.html index.html
    2

  2)通过主机目录映射到容器

  1.  docker  run  -p  80:80  -d  -v  $PWD/html:usr/share/nginx/html  docker.io/nginx
  1. -v  $PWD/html:usr/share/nginx/html   表示把当前路径下html目录映射为usr/share/nginx/html
  1. 也就是说主机下的html就是容器下的usr/share/nginx/html
  1. html内的文件修改和添加就等同于容器usr/share/nginx/html文件操作
  1. 外网访问就可以访问得到,就不用再登录容器操作文件了
  1.  

4. 停止服务

  1. [root@localhost my.Shells]# docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. c0462d5e1878 docker.io/nginx "nginx -g 'daemon off" 56 minutes ago Up 56 minutes 0.0.0.0:8080->80/tcp angry_mccarthy
  4. [root@localhost my.Shells]# docker stop c0462d5e1878
  5. c0462d5e1878
  6. [root@localhost my.Shells]# docker ps
  7. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

5. 重启服务

  1. [root@localhost my.Shells]# docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. [root@localhost my.Shells]# docker start c0462d5e1878
  4. c0462d5e1878
  5. [root@localhost my.Shells]# docker ps
  6. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  7. c0462d5e1878 docker.io/nginx "nginx -g 'daemon off" 59 minutes ago Up 12 seconds 0.0.0.0:8080->80/tcp angry_mccarthy

6. 再开启一个相同的服务

  1. [root@localhost my.Shells]# docker run -p 8081:80 -d docker.io/nginx
  2. //再开启一个服务,端口为8081
  3. 1fd8a0b5d138203150f1cdbfb9690235159159881785a4654abb04c7c96c5b18
  4. [root@localhost my.Shells]# docker ps //会有两个进程,一个8080,一个8081
  5. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  6. 1fd8a0b5d138 docker.io/nginx "nginx -g 'daemon off" 4 seconds ago Up 3 seconds 0.0.0.0:8081->80/tcp suspicious_hypatia
  7. c0462d5e1878 docker.io/nginx "nginx -g 'daemon off" About an hour ago Up 4 minutes 0.0.0.0:8080->80/tcp angry_mccarthy

  1. 上图访问的是新开启的8081服务
    注意:新启动的服务和原先的服务是两个容器,原先的hello.html在新服务中是没有的

7. 卸载服务

  1. [root@localhost my.Shells]# docker ps //此时8080和8081都在运行
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. 1fd8a0b5d138 docker.io/nginx "nginx -g 'daemon off" 4 minutes ago Up 4 minutes 0.0.0.0:8081->80/tcp suspicious_hypatia
  4. c0462d5e1878 docker.io/nginx "nginx -g 'daemon off" About an hour ago Up 8 minutes 0.0.0.0:8080->80/tcp angry_mccarthy
  5. [root@localhost my.Shells]# docker stop 1fd8a0b5d138 //停下8081
  6. 1fd8a0b5d138
  7. [root@localhost my.Shells]# docker ps //就剩8080还在运行
  8. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  9. c0462d5e1878 docker.io/nginx "nginx -g 'daemon off" About an hour ago Up 9 minutes 0.0.0.0:8080->80/tcp angry_mccarthy
  10. [root@localhost my.Shells]# docker ps -a //可以看到8080在运行,8081已经Exited
  11. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  12. 1fd8a0b5d138 docker.io/nginx "nginx -g 'daemon off" 5 minutes ago Exited (0) 7 seconds ago suspicious_hypatia
  13. c0462d5e1878 docker.io/nginx "nginx -g 'daemon off" About an hour ago Up 9 minutes 0.0.0.0:8080->80/tcp angry_mccarthy
  14. [root@localhost my.Shells]#
  15.  
  16. [root@localhost my.Shells]# docker rm 1fd8a0b5d138 //移除这个进程进行了,注意运作着的进程是无法rm的,要先stop
  17. 1fd8a0b5d138
 
分类: linux

Docker容器进入的4种方式


  在使用Docker创建了容器之后,大家比较关心的就是如何进入该容器了,其实进入Docker容器有好几多种方式,这里我们就讲一下常用的几种进入Docker容器的方法。

进入Docker容器比较常见的几种做法如下:

  • 使用docker attach
  • 使用SSH
  • 使用nsenter
  • 使用exec

一、使用docker attach进入Docker容器

  Docker提供了attach命令来进入Docker容器。

  接下来我们创建一个守护态的Docker容器,然后使用docker attach命令进入该容器。

  1. $ sudo docker run -itd ubuntu:14.04 /bin/bash

  然后我们使用docker ps查看到该容器信息,接下来就使用docker attach进入该容器

  1. $ sudo docker attach 44fc0f0582d9


  可以看到我们已经进入到该容器中了。

  但在,使用该命令有一个问题。当多个窗口同时使用该命令进入该容器时,所有的窗口都会同步显示。如果有一个窗口阻塞了,那么其他窗口也无法再进行操作。

因为这个原因,所以docker attach命令不太适合于生产环境,平时自己开发应用时可以使用该命令。

二、使用SSH进入Docker容器

  在生产环境中排除了使用docker attach命令进入容器之后,相信大家第一个想到的就是ssh。在镜像(或容器)中安装SSH Server,这样就能保证多人进入

容器且相互之间不受干扰了,相信大家在当前的生产环境中(没有使用Docker的情况)也是这样做的。但是使用了Docker容器之后不建议使用ssh进入到Docker容

器内。关于为什么不建议使用,请参考如下文章:

为什么不需要在 Docker 容器中运行 sshd

三、使用nsenter进入Docker容器

  在上面两种方式都不适合的情况下,还有一种比较方便的方法,即使用nsenter进入Docker容器。关于什么是nsenter请参考如下文章:

https://github.com/jpetazzo/nsenter

在了解了什么是nsenter之后,系统默认将我们需要的nsenter安装到主机中

如果没有安装的话,按下面步骤安装即可(注意是主机而非容器或镜像)

具体的安装命令如下:

  1. $ wget https://www.kernel.org/pub/linux/utils/util-linux/v2.24/util-linux-2.24.tar.gz
  2. $ tar -xzvf util-linux-2.24.tar.gz
  3. $ cd util-linux-2.24/
  4. $ ./configure --without-ncurses
  5. $ make nsenter
  6. $ sudo cp nsenter /usr/local/bin

安装好nsenter之后可以查看一下该命令的使用。

  nsenter可以访问另一个进程的名称空间。所以为了连接到某个容器我们还需要获取该容器的第一个进程的PID。可以使用docker inspect命令来拿到该PID。

docker inspect命令使用如下:

  1. $ sudo docker inspect --help   

inspect命令可以分层级显示一个镜像或容器的信息。比如我们当前有一个正在运行的容器

可以使用docker inspect来查看该容器的详细信息。

  1. $ sudo docker inspect 44fc0f0582d9

由其该信息非常多,此处只截取了其中一部分进行展示。如果要显示该容器第一个进行的PID可以使用如下方式

  1. $ sudo docker inspect -f {{.State.Pid}} 44fc0f0582d9

在拿到该进程PID之后我们就可以使用nsenter命令访问该容器了。

  1. $ sudo nsenter --target 3326 --mount --uts --ipc --net --pid
  1. $ sudo nsenter --target 3326 --mount --uts --ipc --net --pid

其中的3326即刚才拿到的进程的PID

当然,如果你认为每次都输入那么多参数太麻烦的话,网上也有许多做好的脚本供大家使用。

地址如下:

http://yeasy.gitbooks.io/docker_practice/content/container/enter.html

http://www.tuicool.com/articles/eYnUBrR

四、使用docker exec进入Docker容器

  除了上面几种做法之外,docker在1.3.X版本之后还提供了一个新的命令exec用于进入容器,这种方式相对更简单一些,下面我们来看一下该命令的使用:

  1. $ sudo docker exec --help

接下来我们使用该命令进入一个已经在运行的容器

  1. $ sudo docker ps
  2. $ sudo docker exec -it 775c7c9ee1e1 /bin/bash

查看docker name:

sudo docker inspect -f='{{.Name}}' $(sudo docker ps -a -q)

查看dockers ip:

sudo docker inspect -f='{{.NetworkSettings.IPAddress}}' $(sudo docker ps -a -q)

Docker创建固定ip:

Docker安装后,默认会创建下面三种网络类型

  1. $ docker network ls
  2. NETWORK ID NAME DRIVER SCOPE
  3. 9781b1f585ae bridge bridge local
  4. 1252da701e55 host host local
  5. 237ea3d5cfbf none null local

启动 Docker的时候,用 --network 参数,可以指定网络类型

  1. docker run -itd --name test1 --network bridge --ip 172.17.0.10 centos:latest /bin/bash

bridge:桥接网络

  1. 默认情况下启动的Docker容器,都是使用 bridgeDocker安装时创建的桥接网络,每次Docker容器重启时,会按照顺序获取对应的IP地址,这个就导致重启下,DockerIP地址就变了

none:无指定网络

  1. 使用 --network=none docker 容器就不会分配局域网的IP

host: 主机网络

  1. 使用 --network=host,此时,Docker 容器的网络会附属在主机上,两者是互通的。
  2. 例如,在容器中运行一个Web服务,监听8080端口,则主机的8080端口就会自动映射到容器中。

创建自定义网络:(设置固定IP)

  1. 启动Docker容器的时候,使用默认的网络是不支持指派固定IP的,如下
  2. docker run -itd --net bridge --ip 172.17.0.10 centos:latest /bin/bash
  3. 6eb1f228cf308d1c60db30093c126acbfd0cb21d76cb448c678bab0f1a7c0df6
  4. docker: Error response from daemon: User specified IP address is supported on user defined networks only.

步骤1: 创建自定义网络

  1. docker network create --subnet=172.18.0.0/16 mynetwork
  2. ~ docker network ls
  3. NETWORK ID NAME DRIVER SCOPE
  4. 9781b1f585ae bridge bridge local
  5. 1252da701e55 host host local
  6. 4f11ae9c85de mynetwork bridge local
  7. 237ea3d5cfbf none null local

步骤2: 创建Docker容器

  1. docker run -itd --name networkTest1 --net mynetwork --ip 172.18.0.2 centos:latest /bin/bash
 
更改docker镜像存储目录:

默认情况下,docker镜像的默认存储路径是/var/lib/docker,这相当于直接挂载系统目录下,而一般在搭系统时,这个区都不会太大,所以如果长期使用docker开发应用,就需要把默认的路径更改到/home路径下(这个区一般会分得比较多)

命令行:

vi /usr/lib/systemd/system/docker.service

在文本内容ExecStart=/usr/bin/dockerd 后面添加如下内容:

--graph  /home/data/docker使得变成:

ExecStart=/usr/bin/dockerd \

--graph /home/data/docker

然后重新加载配置文件

systemctl daemon-reload

最后重启即可

systemctl restart docker

注:更改过后,之后卸载docker并删除所有镜像和容器的目录,就要rm -rf <your path>

 
添加docker国内镜像:
  1. $ vim /etc/docker/daemon.json
  2.  
  3. {
  4. "registry-mirrors": ["https://registry.docker-cn.com"]
  5. }
   重启docker:
   systemctl daemon-reload 
   systemctl restart docker
 
添加非root用户,具有docker操作权限省去sudo:

Docker守候进程绑定的是一个unix  socket,而不是TCP端口。这个套接字默认的属主是root,其他是用户可以使用sudo命令来访问这个套接字文件。因为这个原因,docker服务进程都是以root帐号的身份运行的。

为了避免每次运行docker命令的时候都需要输入sudo,可以创建一个docker用户组,并把相应的用户添加到这个分组里面。当docker进程启动的时候,会设置该套接字可以被docker这个分组的用户读写。这样只要是在docker这个组里面的用户就可以直接执行docker命令了。

警告:该dockergroup等同于root帐号,具体的详情可以参考这篇文章:Docker Daemon Attack Surface.

root下新建docker组:

  groupadd docker
新建用户zm:
  useradd zm
  passwd zm
添加用户到组:
usermod -aG dockerroot zm
usermod -aG docker zm
重启docker:
systemctl restart docker
切换到zm验证是否生效:
docker info
 
docker设置固定ip:
https://blog.csdn.net/wanghao_0206/article/details/79583325
查看docker network:
 docker network ls
创建network:
docker network create --subnet=198.8.18.0/24 net18
用指定ip启动docker:
docker run -it --name net18test --net net18 --ip 198.8.18.101 docker.io/centos /bin/bash
 
docker挂载外部目录:
docker run -it --name net18102 --net net18 --ip 198.8.18.102 -v /home/data/net18102/:/mnt/ docker.io/centos /bin/bash
--name net18102                             名称
--net net18 --ip 198.8.18.102          固定ip
 -v /home/data/net18102/:/mnt/      本机目录:docker目录
 docker.io/centos                             使用镜像
/bin/bash
 
windows主机访问docker不通要添加路由:
主机     198.8.8.100
虚拟机  198.8.8.200
docker  198.8.18.101
管理员权限运行cmd:
route add 198.8.18.0 mask 255.255.255.0 198.8.8.200
 
参考:
https://www.cnblogs.com/xhyan/p/6593075.html
https://www.cnblogs.com/wwzyy/p/8337965.html
https://blog.csdn.net/zzy1078689276/article/details/77371782
https://blog.csdn.net/u013948858/article/details/78412573
 

centos7中docker操作的更多相关文章

  1. 使用ssh连接到centos7中docker容器

    任务: 使用ssh连接到centos7中docker容器 实验步骤: 实验环境搭建,详情请看上一篇. 因为docker中容器的ip通常来说是和真机以及centos7的ip不属于一个网段,因此直接访问是 ...

  2. Centos7中docker开启远程访问

    在作为docker远程服务的centos7机器中配置: 1.在/usr/lib/systemd/system/docker.service,配置远程访问.主要是在[Service]这个部分,加上下面两 ...

  3. 在centos7 中docker info报错docker bridge-nf-call-iptables is disabled 的解决方法

    在centos7中安装好docker以后,启动成功,运行命令 docker info ,报错: [root@iz2ze2bn5x2wqxdeq65wlpz ~]# docker info Client ...

  4. docker 在centos7中设置 DOCKER_OPTS

    不同于Ubuntu目录 /etc/default/docker. 在 CentOS7中Docker默认配置的路径在 /usr/lib/systemd/system/docker.service [例如 ...

  5. CentOS7开启docker远程访问并在idea中连接使用

    CentOS7开启docker远程访问并在idea中连接使用 1.编辑/usr/lib/systemd/system/docker.service,配置远程访问.主要是在[Service]这个部分,添 ...

  6. CentOS7下Docker中构建Jenkins容器

    背景 在CentOS搭建Docker完成后,我们需要在Docker中搭建Jenkins用来实现工程自动部署. 安装前提 jdk已安装,安装目录如:usr/java/jdk1.8.0_161 maven ...

  7. 在Centos7中安装Docker并实例化Mysql

    首先 本文是一篇安装流程,从初始的Centos7安装Docker后实例化一个Mysql的整个流程,其中会包含一些需要注意的疑点和坑. 实例化的Mysql是将数据和配置保存在宿主机. 注意,在安装Doc ...

  8. Docker - 在CentOS7中安装Docker

    在CentOS 7中安装Docker 1-确认系统信息 # cat /etc/redhat-release CentOS Linux release 7.2.1511 (Core) # uname - ...

  9. Docker 操作记录

    Docker docker info 查看信息 docker 更改镜像目录 方式:1.配置文件修改 # cat /etc/sysconfig/docker |grep -v ^# |grep -v ^ ...

随机推荐

  1. Getting Started with Processing 第二,三章总结

    第一章是文化熏陶. 第二章:开始编程 菜单栏中的 Show 的快捷键 Run:进行显示shortcut:可以通过快捷键 cmd + R 执行Present:进行全屏的显示shortcut:可以通过按下 ...

  2. You Don't Know JS: Scope & Closures (第4章: Hoisting)

    Chapter4: Hoisting 变量附加到哪个层次的scope,由它们在哪里和如何声明(let, var)来决定. Function scope/Block scope都有相同的法则:任何变量在 ...

  3. php单例模式的使用场景,使用方法

    一个类只有一个对象实例 1.含义 作为对象的创建模式,单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统全局地提供这个实例.它不会创建实例副本,而是会向单例类内部存储的实例返回一个引用. 2 ...

  4. 2.4 UML类图

    类图定义 类class的定义 具有相同属性.操作.方法.关系或者行为的一组对象的描述符 类是真实世界事物的抽象 问题领域的类:在对系统建模时,将会涉及到如何识别业务系统中的事物,这些事物构 成了整个业 ...

  5. Robbers' watch CodeForces - 685A (暴力)

    大意: 一天n小时, m分钟, 表以7进制显示, 求表显示数字不同的方案数 注意到小时和分钟部分总长不超过7, 可以直接暴力枚举. 关键要特判0, 0的位数要当做1来处理 #include <i ...

  6. 『TensorFlow』SSD源码学习_其八:网络训练

    Fork版本项目地址:SSD 作者使用了分布式训练的写法,这使得训练部分代码异常臃肿,我给出了部分注释.我对于多机分布式并不很熟,而且不是重点,所以不过多介绍,简单的给出一点训练中作者的优化手段,包含 ...

  7. spring boot(一)入门

    什么是spring boot Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员 ...

  8. js中去掉字符串的空格、回车换行

    //例如下面这个json串,中间的\n表示换行 var str = "{' retmsg':'success ',\n' trans_date':' 20170906'}"; co ...

  9. Java异常及错误

    java提供了两种异常机制,可以分为运行时异常(RuntimeException)与检查式异常(checked Exception). 检查式异常:java编译器对于这种异常需要我们对其用try... ...

  10. WDA基础九:BusinessGraphics

    好像很少有人用这玩意...好难玩,好废...和ABAP的那个图一样废.... 很多报表都是用BO,BI什么做的,不仅废,而且很多BO顾问不懂代码,写出来的报表挫的要死.... WDA的网页图形报表分析 ...