Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源。
Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。
容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。Docker是在Unbutu上进行开发的,所以CentOs和Unbutu而言,Unbutu更好一些
Web 应用的自动化打包和发布。
自动化测试和持续集成、发布。
在服务型环境中部署和调整数据库或其他的后台应用
1、简化程序:
Docker 让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,便可以实现虚拟化。Docker改变了虚拟化的方式,使开发者可以直接将自己的成果放入Docker中进行管理。方便快捷已经是 Docker的最大优势,过去需要用数天乃至数周的 任务,在Docker容器的处理下,只需要数秒就能完成。
2、避免选择恐惧症:
如果你有选择恐惧症,还是资深患者。Docker 帮你 打包你的纠结!比如 Docker 镜像;Docker 镜像中包含了运行环境和配置,所以 Docker 可以简化部署多种应用实例工作。比如 Web 应用、后台应用、数据库应用、大数据应用比如 Hadoop 集群、消息队列等等都可以打包成一个镜像部署。
3、节省开支:
一方面,云计算时代到来,使开发者不必为了追求效果而配置高额的硬件,Docker 改变了高性能必然高价格的思维定势。Docker 与云的结合,让云空间得到更充分的利用。不仅解决了硬件管理的问题,也改变了虚拟化的方式
Docker 官网:http://www.docker.com
Github Docker 源码:https://github.com/docker/docker
Docker 镜像: https://hub.docker.com (需要注册账号和密码)
网易hub https://c.163yun.com/hub#/m/home/ (需要注册账号和密码)
阿里云镜像 https://dev.aliyun.com/search.html (需账号和密码)
Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器。
Docker 容器通过 Docker 镜像来创建。
容器与镜像的关系类似于面向对象编程中的对象与类
Docker | 面向对象 |
---|---|
容器 | 对象 |
镜像 | 类 |
Docker 镜像(Images) |
Docker 镜像是用于创建 Docker 容器的模板。 |
Docker 容器(Container) |
容器是独立运行的一个或一组应用。 |
Docker 客户端(Client) |
Docker 客户端通过命令行或者其他工具使用 Docker API (https://docs.docker.com/reference/api/docker_remote_api) 与 Docker 的守护进程通信。 |
Docker 主机(Host) |
一个物理或者虚拟的机器用于执行 Docker 守护进程和容器。 |
Docker 仓库(Registry) |
Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库。 Docker Hub(https://hub.docker.com) 提供了庞大的镜像集合供使用。
|
Docker Machine |
Docker Machine是一个简化Docker安装的命令行工具,通过一个简单的命令行即可在相应的平台上安装Docker,比如VirtualBox、 Digital Ocean、Microsoft Azure。
|
Docker 支持以下的 Ubuntu 版本:
Docker 要求 Ubuntu 系统的内核版本高于 3.10 ,查看本页面的前提条件来验证你的 Ubuntu 版本是否支持 Docker。
通过 uname -r 命令查看你当前的内核版本
runoob@runoob:~$ uname -r
runoob@runoob:~$ wget -qO- https://get.docker.com/ | sh
输入当前用户的密码后,就会下载脚本并且安装Docker及依赖包。
安装完成后有个提示:
If you would like to use Docker as a non-root user, you should now consider
adding your user to the "docker" group with something like:
sudo usermod -aG docker runoob
Remember that you will have to log out and back in for this to take effect!
当要以非root用户可以直接运行docker时,需要执行 sudo usermod -aG docker runoob 命令,然后重新登陆,否则会有如下报错
runoob@runoob:~$ sudo service docker start
3、测试运行hello-world
runoob@runoob:~$ docker run hello-world
鉴于国内网络问题,后续拉取 Docker 镜像十分缓慢,我们可以需要配置加速器来解决,我使用的是网易的镜像地址:http://hub-mirror.c.163.com。
新版的 Docker 使用 /etc/docker/daemon.json(Linux) 或者 %programdata%\docker\config\daemon.json(Windows) 来配置 Daemon。
请在该配置文件中加入(没有该文件的话,请先建一个):
{
"registry-mirrors": ["http://hub-mirror.c.163.com"]
}
Docker支持以下的CentOS版本:
目前,CentOS 仅发行版本中的内核支持 Docker。
Docker 运行在 CentOS 7 上,要求系统为64位、系统内核版本为 3.10 以上。
Docker 运行在 CentOS-6.5 或更高的版本的 CentOS 上,要求系统为64位、系统内核版本为 2.6.32-431 或者更高版本。
Docker 要求 CentOS 系统的内核版本高于 3.10 ,查看本页面的前提条件来验证你的CentOS 版本是否支持 Docker 。
通过 uname -r 命令查看你当前的内核版本[root@runoob ~]# uname -r 3.10.0-327.el7.x86_64
从 2017 年 3 月开始 docker 在原来的基础上分为两个分支版本: Docker CE 和 Docker EE。
Docker CE 即社区免费版,Docker EE 即企业版,强调安全,但需付费使用。
本文介绍 Docker CE 的安装使用。
移除旧的版本:
$ sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-selinux \
docker-engine-selinux \
docker-engine
安装一些必要的系统工具:
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
添加软件源信息:
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
更新 yum 缓存:
sudo yum makecache fast
安装 Docker-ce:
sudo yum -y install docker-ce
启动 Docker 后台服务
sudo systemctl start docker
测试运行 hello-world
[root@runoob ~]# docker run hello-world
由于本地没有hello-world这个镜像,所以会下载一个hello-world的镜像,并在容器内运行。
1、使用 sudo
或 root
权限登录 Centos。
2、确保 yum 包更新到最新。
$ sudo yum update
3、执行 Docker 安装脚本。
$ curl -fsSL https://get.docker.com -o get-docker.sh
$ sudo sh get-docker.sh
执行这个脚本会添加 docker.repo
源并安装 Docker。
4、启动 Docker 进程。
sudo systemctl start docker
5、验证 docker
是否安装成功并在容器中执行一个测试的镜像。
$ sudo docker run hello-world
docker ps
到此,Docker 在 CentOS 系统的安装完成。
鉴于国内网络问题,后续拉取 Docker 镜像十分缓慢,我们可以需要配置加速器来解决,我使用的是网易的镜像地址:http://hub-mirror.c.163.com。
新版的 Docker 使用 /etc/docker/daemon.json(Linux) 或者 %programdata%\docker\config\daemon.json(Windows) 来配置 Daemon。
请在该配置文件中加入(没有该文件的话,请先建一个):
{
"registry-mirrors": ["http://hub-mirror.c.163.com"]
}
执行以下命令来删除 Docker CE:
$ sudo yum remove docker-ce
$ sudo rm -rf /var/lib/docker
Ubuntu16.04下
以下命令行皆是在终端中运行:
安装xrdp
sudo apt-get install xrdp
安装vnc4server
sudo apt-get install vnc4server
安装xubuntu-desktop
sudo apt-get install xubuntu-desktop
向xsession中写入xfce4-session(每个用户自己运行此行)
echo "xfce4-session" >~/.xsession
开启xrdp服务
sudo service xrdp restart
接着windows远程访问即可,输入mstsc
docker search nginx
docker pull nginx
docker run -d -p 82:80 --name nginx1 -d nginx (启动容器) ,将Docker容器的80端口映射到82端口上)
curl localhost:82
docker search mongo
docker pull mongo
docker run -d -p 27017:27017 --name mongodb -d mongo
docker pull mongo-express
docker run -itd -p 27018:8081 --link mongDb运行容器的ID:mongo mongo-express
docker search redis
docker pull redis
docker run -d -p 6379:6379 --name redis -d redis
Docker 安装treenms(treesoft) 来管理redis或者Memcache
docker run -d -p 8085:8080 --name treenms -v /etc/localtime:/etc/localtime --restart=always fuyong/treenms
访问
docker search rabbitmq
docker pull rabbitmq:3.7.7-management
docker run -p 5672:5672 -p 15672:15672 --name rabbitmq -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=admin -d rabbitmq:3.7.7-management
http://localhost:15672
docker pull java:8
docker run -d -it java:8 /bin/bash
docker exec -it 8c7337c6e324/bin/bash // 8c7337c6e324 为java8运行时,生成的容器id
java -version
docker pull hub.c.163.com/library/mysql
docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -e MYSQL_DATABASE=jpress hub.c.163.com/library/mysql
(mysql用户名默认为root,密码为123456,创建的数据库名为jpress)
docker pull uifd/ui-for-docker
docker run -it -d --name docker-web -p 9000:9000 -v /var/run/docker.sock:/var/run/docker.sock docker.io/uifd/ui-for-docker
http://localhost:9000
9. Docker 打包SpringBoot jar为images
在liunx中执行 mkdir test1
接着给test1里面上传一个springJar包,如下所示:
接着用vim执行生成一个Dockfile文件
Dockfile里面的内容为:
FROM java:8
VOLUME /tmp
ADD okHttp-1.2-SNAPSHOT.jar app.jar
ENTRYPOINT ["java","-jar","/app.jar"]
接着运行构建
构建
docker build -t springbootok:latest . -f Dockerfile
运行
docker run -p 6080:6080 --name springbootok -d springbootok
10. jpress构建
准备工作:需要下载最新的jpress.war,需要准备mysql数据库,我们将将jpress.war和Tomcat制成一个统一的images镜像,
打包发布时候,然后再让jpress容器和mysql关联起来即可
jpress.war下载地址: https://gitee.com/GalaIO/jpress/blob/master/wars/jpress-web-newest.war
Dockfile的内容为:
from hub.c.163.com/library/tomcat:latest
COPY jpress.war /usr/local/tomcat/webapps/
接着我们执行docker build -t jpress:latest . -f Dockerfile
运行:
docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -e MYSQL_DATABASE=jpress hub.c.163.com/library/mysql
docker run -d -p 8082:8080 --name jpress -d jpress
依次登陆网页进行设置:
http://localhost:8082/jpress/install
数据库 jpress 账号 root 密码:123456
网站管理员 账号密码 root 123456
http://localhost:8082/jpress/admin/login
11. wordPress构建
docker run -d -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 -e MYSQL_DATABASE=wordPress hub.c.163.com/library/mysql
docker run --name wordPress --link f9dd05fa95ce:hub.c.163.com/library/mysql -e WORDPRESS_DB_USER=root -e WORDPRESS_DB_PASSWORD=123456 -p 8201:80 -d wordpress
http://localhost:8201
http://localhost::8201/wp-admin/
Docker 常见的几个命令:
docker run
docker ps (查看正在运行的容器) docker start (启动一个或者多个) docker stop 容器id(停止正在运行的容器)
docker ps-a(查看运行和非运行的容器) docker rm 容器id(移除掉某个不在运行的docker容器)
docker rim imagesId (移除掉images)
docker之进入启动容器查看目录结构 docker exec -it c86e /bin/bash 或者执行里面的命令
学习参考资料 http://www.runoob.com/docker/docker-tutorial.html
Windows操作linux工具 MobaXterm.exe
11. docker 构建 elasticsearch
docker pull elasticsearch
docker run -d -p 9200:9200 -p 9300:9300 -e "ES_JAVA_OPTS=-Xms512m -Xmx512m" --name=elasticsearch elasticsearch
elasticsearch5.+配置默认的内存是2g。我给docker的内存也只有2g,于是就GG了
删除了旧容器,和旧镜像后,在docker启动命令中加上-e "ES_JAVA_OPTS=-Xms512m -Xmx512m"
解决问题
http://127.0.0.1:9200/
docker images : 列出本地镜像
docker pull : 从镜像仓库中拉取或者更新指定镜像
docker run :创建一个新的容器并运行一个命令
-d: 后台运行容器,并返回容器ID
-p: 端口映射,格式为:主机(宿主)端口:容器端口
--name="nginx-lb": 为容器指定一个名称
-v:目录映射,格式为:主机目录:容器目录
docker rm :删除一个或多个容器
docker start :启动一个或多少已经被停止的容器
docker stop :停止一个运行中的容器
docker kill :杀掉一个运行中的容器(强制)
docker restart :重启容器
docker port :列出指定的容器的端口映射,或者查找将PRIVATE_PORT NAT到面向公众的端口。
docker logs : 获取容器的日志
-f : 跟踪日志输出
--since :显示某个开始时间的所有日志
-t : 显示时间戳
--tail :仅列出最新N条容器日志
docker exec -i -t mynginx /bin/bash:在容器mynginx中开启一个交互模式的终端,即通过SSH协议进入容器
docker ps : 列出容器
-a :显示所有的容器,包括未运行的。
docker cp:拷贝主机docker cp /www/runoob 96f7f14e99ab:/www/