前言
之前在window下都是使用vmware安装linux虚拟机,需要进行繁琐的网络配置。最近换了一台新电脑,想装个centos玩玩,,于是选择docker安装centos,简单轻量。
详细过程
环境:win10、已安装docker,
1、从dockers hub上查看我们需要的centos版本,这里我安装centos7
2、拉取镜像
docker pull centos:7 格式为 镜像名:TAG
docker pull centos:7
3、拉取完之后,查看一下镜像
docker image ls
4、以互交方式后台运行容器
docker run -it -d -p 50001:22 67fa590cfc1c /bin/bash
5、查看当前运行的容器,并进入容器
docker ps
docker attach 945c6b2155c7
6、查看网络配置,ifconfig
这是因为使用docker pull centos命令下载下来的centos镜像是centos7的最小安装包,里面并没有携带ifconfig命令
使用如下命令:
yum provides ifconfig
yum whatprovides ifconfig
以上两个命令时用于输出哪些包包含我们要查找的文件,从结果可以看到,我们要找的包是:net-tools
因此,再输入:yum install net-tools,安装完成后就可以使用ifconfig命令了
7、安装ssh服务
yum install openssh-server -y
执行如下命令:
[root@945c6b2155c7 /]# yum list | grep initscripts
initscripts.x86_64 9.49.47-1.el7 base
[root@945c6b2155c7 /]# yum install initscripts -y
安装成功再次运行 service sshd start
还是不行,经查找原因如下:
刚开始接触Docker的朋友,可能会遇到这么一个问题,使用centos7镜像创建容器后,在里面使用systemctl启动服务报错。针对这个报错,我们接下来就分析下!
# docker run -itd --name centos7 centos:7
# docker attach centos7
# yum install vsftpd
# systemctl start vsftpd
Failed to get D-Bus connection: Operation not permitted
不能启动服务,什么情况?
难道容器不能运行服务嘛!!!
答:
Docker的设计理念是在容器里面不运行后台服务,容器本身就是宿主机上的一个独立的主进程,也可以间接的理解为就是容器里运行服务的应用进程。一个容器的生命周期是围绕这个主进程存在的,所以正确的使用容器方法是将里面的服务运行在前台。
再说到systemd,这个套件已经成为主流Linux发行版(比如CentOS7、Ubuntu14+)默认的服务管理,取代了传统的SystemV风格服务管理。systemd维护系统服务程序,它需要特权去会访问Linux内核。而容器并不是一个完整的操作系统,只有一个文件系统,而且默认启动只是普通用户这样的权限访问Linux内核,也就是没有特权,所以自然就用不了!
因此,请遵守容器设计原则,一个容器里运行一个前台服务!
我就想这样运行,难道解决不了吗?
答:可以,以特权模式运行容器。
docker run -it -p 50001:22 --privileged centos /usr/sbin/init
但是按这种方式运行后,还是不行,在初始化过程中卡住不动了
实在没办法,换了一个centos 6.7版本就可以了