Docker篇


CentOS 安装Docker - 菜鸟教程

安装须知:
1.Docker支持以下的CentOS版本:
CentOS 7 (64-bit)
CentOS 6.5 (64-bit) 或更高的版本 2.Docker 要求 CentOS 系统的内核版本高于 3.10 ,查看本页面的前提条件来验证你的CentOS 版本是否支持 Docker 。
通过 uname -r 命令查看你当前的内核版本

安装一些必要的系统工具:

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

会自动下载一个镜像运行

注意配置CDN加速:

鉴于国内网络问题,后续拉取 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正式使用常见命令

Docker-Hub注册:https://hub.docker.com/signup

Docker验证登录

docker login

Docker寻找镜像

docker search tomcat

Docker拉取镜像

docker pull tomcat

Docker查看本地镜像

docker images

Docker删除镜像和容器

docker删除镜像:
docker rmi 镜像ID
如果是本地的包含tag的话需要指明
docker rmi 806857264/kerwin_docker:kerwin_tomcat_8080 docker删除容器:
首先需要停止容器
docker stop 【id名字】
docker rm 【id名字】

Docker查看正在运行的容器

docker ps

查看所有容器
docker ps -a

Docker交互模式进入到目标文件目录

docker exec -it d585d5151285 /bin/bash   交互模式进入到目标文件目录,可以进行修改等,如进入到tomcat目录
d585d5151285为容器ID

停止容器/重启容器

docker stop 【名字】
docker start 【名字】
docker restart 【名字】

Docker运行镜像

如tomcat为例:
docker run --name tomcat-80 -p 80:8080 -v /home/docker_tomcat:/usr/local/tomcat/webapps -d tomcat
重命名为tomcat-80 端口映射 80->8080 宿主机文件交互目录 运行的镜像为tomcat :ro赋予可读权限

Docker部署redis

redis.conf 配置文件 --- 

创建:/home/docker_redis/conf
创建:/home/docker_redis/data ze yes
#设置进程锁文件
pidfile /redis/redis.pid
#端口
port 6379
#客户端超时时间
timeout 1500
#日志级别
loglevel debug
#日志文件位置
logfile /log/log-docker_redis.log
#设置数据库的数量,默认数据库为0,可以使用SELECT <dbid>命令在连接上指定数据库id
databases 8
##指定在多长时间内,有多少次更新操作,就将数据同步到数据文件,可以多个条件配合
#save <seconds> <changes>
#Redis默认配置文件中提供了三个条件:
save 900 1
save 300 10
save 60 10000
#指定存储至本地数据库时是否压缩数据,默认为yes,Redis采用LZF压缩,如果为了节省CPU时间,
#可以关闭该#选项,但会导致数据库文件变的巨大
rdbcompression yes
#指定本地数据库文件名
dbfilename dump.rdb
#指定本地数据库路径
dir /redis/db/
#指定是否在每次更新操作后进行日志记录,Redis在默认情况下是异步的把数据写入磁盘,如果不开启,可能
#会在断电时导致一段时间内的数据丢失。因为 redis本身同步数据文件是按上面save条件来同步的,所以有
#的数据会在一段时间内只存在于内存中
appendonly no
#指定更新日志条件,共有3个可选值:
#no:表示等操作系统进行数据缓存同步到磁盘(快)
#always:表示每次更新操作后手动调用fsync()将数据写到磁盘(慢,安全)
#everysec:表示每秒同步一次(折衷,默认值)
appendfsync everysec
#redis配置外网访问:
protected-mode no #配置密码
requirepass 123456 运行命令: 如redis为例:
docker run -d --privileged=true -p 56379:6379 -v /docker/redis/conf/redis.conf:/etc/redis/redis.conf -v /docker/redis/data:/data --name redis_56379 redis redis-server /etc/redis/redis.conf --appendonly yes --requirepass 123456 映射ip 56379->6379 映射宿主机文件夹(配置文件和数据) 启动redis-server 按配置文件启动 密码规定为123456

Docker部署nginx进行反向代理

docker pull nginx
创建对应文件夹,进行目录映射 运行nginx镜像:
docker run --name nginx-80 -d -p 80:80 -v /home/docker_nginx/html:/usr/share/nginx/html -v /home/docker_nginx/nginx.conf:/etc/nginx/nginx.conf:ro -v /home/docker_nginx/conf.d:/etc/nginx/conf.d nginx ip映射80,文件夹映射,注意nginx.conf:ro 可读权限,conf.d目录下存放对应的配置即可

Nginx配置说明:

nginx.conf  核心配置,可不用修改
user nginx;
worker_processes 1; error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid; events {
worker_connections 1024;
} http {
include /etc/nginx/mime.types;
default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main; sendfile on;
#tcp_nopush on; keepalive_timeout 65; #gzip on;
include /etc/nginx/conf.d/*.conf;
}

Nginx - conf.d目录下配置,针对每一个域名的具体配置

说明:一个域名对应一个文件,如kkzhilu.cn为例
upstream tomcat {
#内网IP,然后限制8080端口对外访问,即可保证用户只从nginx进入,提高访问上限
#另外,如微服务架构的话,限制端口,也可以保证用户只能从网关层进入,保证后台服务的安全
server 172.21.0.8:8080;
} server {
listen 80;
server_name localhost; location / {
proxy_pass http://tomcat;
}
}

参考博文:

docker 快速部署tomcat:https://blog.csdn.net/weixin_39835887/article/details/84516595

51博客:https://blog.51cto.com/11134648/2160257

菜鸟教程

how2j

博客园创建安装基本命令等:https://www.cnblogs.com/lsgxeva/p/8746644.html

镜像制作:https://www.cnblogs.com/iloverain/p/8980275.html

docker 快速部署redis:https://blog.csdn.net/wcuuchina/article/details/86355362

Docker制作镜像推送到仓库

博文地址:https://www.cnblogs.com/yaohong/p/9221800.html

1.制作镜像,可以从公网随意拉一个容器,本地运行,再把它变成镜像即可
2.比如我拉取了tomcat镜像,配置之后会变成容器
3.把最终的运行容器变成镜像 先停止容器运行,再执行:
docker commit -m "my_tomcat" -a "kerwin" tomcat-8080 kerwin_tomcat_8080:v1.0
-m 描述,-a作者 后面是镜像名,然后的推送之后的镜像名最后是版本号 打标,通过images拿到对应镜像的id,再给它重新打标
docker tag 179396596cbd 806857264/kerwin_docker:kerwin_tomcat_8080
docker --- 命令
tag --- 命令
179396596cbd --- 镜像id
806857264/kerwin_docker: --- 用户名和仓库名(仓库没有的话自动创建,所以不用自己去建)
kerwin_tomcat_8080 --- 取的是commit的最终镜像名 最后是push
docker push 806857264/kerwin_docker:kerwin_tomcat_8080
kerwin_tomcat_8080 就是上文打标的目标镜像 去官网:https://cloud.docker.com/repository/list
检查即可 注:为什么要commit推送, 因为在容器内部修改的,配置的文件,在关闭启动之后,会消失,所以,如果有改动内部文件,则需要制作新的镜像,然后推送,如果仅仅是宿主机目录的变化的话,是不需要重新制作镜像的

Docker部署第三方Jar包

指导博文:https://www.cnblogs.com/bxssjava/p/9978449.html

第一步:准备好一个正常完好的jar
第二步:Dockerfile文件 注意不要有后缀 FROM openjdk:8-jdk-alpine
VOLUME /tmp
ADD target/demo_test_nginx-0.0.1-SNAPSHOT.jar app.jar
RUN sh -c 'touch /app.jar'
ENV JAVA_OPTS=""
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"] 第三步:在linux服务器指定的目录下,放好jar和dockerfile文件 第四步:docker build -t 【镜像名字】 .
注意上面的. 表示此目录 第五步:正常运行即可
如:docker run --name demo-10909 -p 10909:10909 -d viando/demo

Docker 自动化部署 - shell命令

创建  docker.sh文件,写入以下命令,将之和jar以及Dockerfile放在一个目录,必要的时候修改 app名,容器名或者镜像名即可
注意必要情况修改端口映射 #!/bin/bash
#JAR 名称 - 替换即可
APP_NAME=demo_test_nginx-0.0.1-SNAPSHOT.jar #容器名称 - 替换即可
CONTAINER_NAME=demo-10909 #镜像名称 - 替换即可
IAMGE_NAME=viando/demo #使用说明,用来提示输入参数
usage() {
echo "Usage: sh 执行脚本.sh [start|build] desc: start is for run jar and build is build images for docker"
exit 1
} #启动方法-包含build过程
start(){
build
docker run --name $CONTAINER_NAME -v /home/log:/log -p 10909:10909 -d $IAMGE_NAME
#挂载日志
} #构建image方法
build(){
docker stop $CONTAINER_NAME
docker rm $CONTAINER_NAME
docker rmi $IAMGE_NAME #构建
docker build -t $IAMGE_NAME .
} #根据输入参数,选择执行对应方法,不输入则执行使用说明
case "$1" in
"start")
start
;;
"build")
build
;;
*)
usage
;;
esac

Docker基础使用的更多相关文章

  1. Docker - Docker基础命令及使用

    Docker Docker - 官网 Docker - Hub GitHub - Docker Docker中文社区 Docker基础命令 Docker 查看帮助信息:docker --help 查看 ...

  2. 【云计算】Docker云平台—Docker基础

    Docker云平台系列共三讲,此为第一讲:Docker基础 参考资料: Docker官方文档:https://docs.docker.com/ Docker从入门到实践:https://yeasy.g ...

  3. Docker基础技术:Linux Namespace(下)

    在 Docker基础技术:Linux Namespace(上篇)中我们了解了,UTD.IPC.PID.Mount 四个namespace,我们模仿Docker做了一个相当相当山寨的镜像.在这一篇中,主 ...

  4. Docker 基础技术:Linux Namespace(下)

    导读 在Docker基础技术:Linux Namespace(上篇)中我们了解了,UTD.IPC.PID.Mount 四个namespace,我们模仿Docker做了一个相当相当山寨的镜像.在这一篇中 ...

  5. Docker基础入门及示例

    Docker近几年的发展可谓一日千里,特别从是2013年随着一个基于LXC的高级容器引擎开源,到现在,其在linux和windows上都有了很好的支持,并且已经有很多公司将docker用于实际的生产环 ...

  6. Docker 基础 : 镜像

    目录 获取镜像 查看镜像信息 搜索镜像 删除镜像 创建镜像 导出和导入镜像 上传镜像 总结 镜像是 Docker 的三大核心概念之一.Docker 运行容器前需要本地存在对应的镜像,如果本地没有对应的 ...

  7. Docker 基础技术之 Linux cgroups 详解

    PS:欢迎大家关注我的公众号:aCloudDeveloper,专注技术分享,努力打造干货分享平台,二维码在文末可以扫,谢谢大家. 推荐大家到公众号阅读,那里阅读体验更好,也沉淀了很多篇干货. 前面两篇 ...

  8. docker 基础知识分享ppt

    给团队做的docker基础分享ppt, 见下面的附件. https://files.cnblogs.com/files/harrychinese/docker_intro.pptx

  9. 中标麒麟龙芯平台--docker基础镜像制作

    Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源.Docker 的出现为开发人员和运维人员带来了极大的便利.Docker在X86下常见的发行版Linux如Ub ...

  10. Docker系列03—Docker 基础入门

    本文收录在容器技术学习系列文章总目录 1.概念介绍 1.1 容器 1.1.1 介绍 容纳其它物品的工具,可以部分或完全封闭,被用于容纳.储存.运输物品.物体可以被放置在容器中,而容器则可以保护内容物. ...

随机推荐

  1. 关于单向循环链表的约瑟夫问题(Java实现)

    关于单向循环链表的约瑟夫问题(Java实现) 最近在学习链表时,遇到单向循环链表中的约瑟夫问题.在构建循环链表的代码上,我有一点很不理解,遂记录下来. Josephu问题为: 设编号为1, 2,.. ...

  2. winxp系统连接服务器丢包解决方法

    winxp系统连接服务器丢包解决方法 MFC编写一个打开网页的程序,发生异常没有获取到数据. 分析步骤: 1. 用getLastError()获取到的信息,(2)- 系统找不到指定的文件. 2. 用浏 ...

  3. 1.尚硅谷_MyBatis_简介.avi

    hibernate旨在消除mysql语句.程序员不写sql语言,要实现复杂的功能需要学习hibernate的hql语句 mybatis把编写sql语言交给程序员,程序员自己在xml控制sql语句的编写 ...

  4. Python 简明教程 --- 11,Python 元组

    微信公众号:码农充电站pro 个人主页:https://codeshellme.github.io 软件工程的目标是控制复杂度,而不是增加复杂性. -- Dr. Pamela Zave 目录 我们在上 ...

  5. 计算机网络之DDOS

    1.什么是DDOS DDOS(Distributed Denial of Service),中文意思为“分布式拒绝服务”,就是利用大量合法的分布式服务器对目标发送请求,从而导致正常合法用户无法获得服务 ...

  6. 主线程用afxBeginThread()创建多个线程安全退出的办法

    HANDLE hand[]; CCriticalSection m_crisecoin; CEvent m_event; struct Student { int nNO; int nYear; CW ...

  7. 洛谷P1220关路灯【区间dp】

    题目描述 某一村庄在一条路线上安装了 \(n\) 盏路灯,每盏灯的功率有大有小(即同一段时间内消耗的电量有多有少).老张就住在这条路中间某一路灯旁,他有一项工作就是每天早上天亮时一盏一盏地关掉这些路灯 ...

  8. 题解 P3870 【[TJOI2009]开关】/基础分块学习小结

    直接进入正题: 分块: 分块分块,就是把一个长串东西,分为许多块,这样,我们就可以在操作一个区间的时候,对于在区间里面完整的块,直接操作块,不完整的直接操作即可,因为不完整,再加上一个块本身就不大,复 ...

  9. c++ 宏定义调用不定参数的函数

    假设有一下函数 void Logging(int nLevel, const char* szFormat, ...); 则宏定义如下 #define LOG(FCFL) Logging##FCFL ...

  10. Python必须知道的异常处理

    异常处理 把可能会发生的错误,提前在代码里进行捕捉(监测) try : code except Exception: 出错后要执行的代码 下面是常见的异常: attributeError 试图访问一个 ...