Ansible-playbook roles用docker容器安装redis主从(学习笔记三十一)

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: docker版本09:49:09 # docker versionClient version: 0.11.1Client API version: 1.

docker版本

09:49:09 # docker version

Client version: 0.11.1

Client API version: 1.11

Go version (client): go1.2.1

Git commit (client): fb99f99/0.11.1

Server version: 0.11.1

Server API version: 1.11

Git commit (server): fb99f99/0.11.1

Go version (server): go1.2.1

Last stable version: 1.1.2, please update docker

ansible版本

09:51:55 # ansible --version

ansible 1.4.3

1、查看已有的docker镜像

09:39:26 # docker images

REPOSITORY          TAG                 IMAGE ID            CREATED             VIRTUAL SIZE

ubuntu              3.0                 6cee55276528        9 weeks ago         369.8 MB

centos5             3.0                 e08d23b09189        9 weeks ago         840.9 MB

centos6             3.0                 e94a3b24a19b        9 weeks ago         415.9 MB

2、查看当前运行的docker容器

09:39:47 # docker ps -a

CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS                   NAMES

846efb9e4d7a        ubuntu:3.0          /usr/sbin/sshd-D   2 weeks ago         Up 6 days           0.0.0.0:49167->22/tcpubuntu-test1        

b9a9e6f2caed        centos6:3.0         /usr/sbin/sshd-D   3 weeks ago         Up 6 days           0.0.0.0:49166->22/tcpzabbix-server       

978fff134b18        centos6:3.0         /usr/sbin/sshd-D   5 weeks ago         Up 6 days           0.0.0.0:49165->22/tcpcentos6-test5       

root@ip-10-10-10-10:/etc/ansible/roles/redis_install/templates

3、加载测试容器

由于是做redis主从,所以需要2个容器

09:39:50 # time  docker inspect $(docker run -d -p 22  --name="redis-master" centos6:3.0 /usr/sbin/sshd -D)|grep -i address|awk -F '"' '{print $4}'

172.17.0.5


real    0m6.369s

user    0m0.036s

sys 0m0.049s

root@ip-10-10-10-10:/etc/ansible/roles/redis_install/templates

09:40:25 # time  docker inspect $(docker run -d -p 22  --name="redis-slave" centos6:3.0 /usr/sbin/sshd -D)|grep -i address|awk -F '"' '{print $4}'

172.17.0.6


real    0m12.567s

user    0m0.047s

sys 0m0.060s

然后把新容器的ip加入到ansible的hosts里

root@ip-10-10-10-10:/etc/ansible/roles/redis_install/templates

09:40:46 # echo "172.17.0.5">>/etc/ansible/hosts

root@ip-10-10-10-10:/etc/ansible/roles/redis_install/templates

09:40:58 # echo "172.17.0.6">>/etc/ansible/hosts

root@ip-10-10-10-10:/etc/ansible/roles/redis_install/templates

4、ansible安装redis的信息

09:52:11 # cat /etc/ansible/roles/redis_install/vars/main.yml 

redis_dir: /data

redis_version: 2.6.17

redis_port: 6379

redis_conf_dir: /data/redis-2.6.17/conf

redis_db_dir: /data/redis-2.6.17/db

redis_log_dir: /data/redis-2.6.17/log

5、下面是redis的playbook结构

09:55:12 # tree /etc/ansible/roles/redis_install /etc/ansible/roles/redis_delete

/etc/ansible/roles/redis_install

├── files

│   └── redis-2.6.17.tar.gz

├── handlers

├── meta

│   └── main.yml

├── tasks

│   ├── copy.yml

│   ├── delete.yml

│   ├── install.yml

│   └── main.yml

├── templates

│   └── redis.conf

└── vars

    └── main.yml

/etc/ansible/roles/redis_delete

├── files

├── handlers

├── meta

│   └── main.yml

├── tasks

│   ├── delete.yml

│   └── main.yml

├── templates

│   └── delete_redis.sh

└── vars

    └── main.yml


12 directories, 13 files

6、playbook安装redis的内容是

09:57:09 # cat redis_install.yml 

---

- hosts: "`host`"

  remote_user: "`user`"

  gather_facts: True

  roles:

    - common

    - redis_install

7、playbook删除redis的内容是

09:57:31 # cat redis_delete.yml 

---

- hosts: "`host`"

  remote_user: "`user`"

  gather_facts: True

  roles:

    - redis_delete

下面是安装redis主从

8、安装redis master

09:43:11 # time ansible-playbook redis_install.yml --extra-vars "host=172.17.0.5 user=root" -k

SSH password: 


PLAY [172.17.0.5] ************************************************************* 


GATHERING FACTS *************************************************************** 

ok: [172.17.0.5]


TASK: [common | Install initializtion require software] *********************** 

changed: [172.17.0.5]


TASK: [redis_install | Copy Redis Software To Redhat Client] ****************** 

ok: [172.17.0.5]


TASK: [redis_install | Create Redis Install Dir] ****************************** 

ok: [172.17.0.5]


TASK: [redis_install | Uncompression Redis Software To Redhat Client] ********* 

changed: [172.17.0.5]


TASK: [redis_install | Copy Redis Config To Redhat Client] ******************** 

changed: [172.17.0.5]


TASK: [redis_install | Create Soft Link In Redhat Client] ********************* 

changed: [172.17.0.5] => (item=redis-cli)

changed: [172.17.0.5] => (item=redis-server)


TASK: [redis_install | Check Boot Start In Redhat Client] ********************* 

failed: [172.17.0.5] => {"changed": true, "cmd": "grep -c '/usr/bin/redis-server /data/redis-2.6.17/conf/redis_6379.conf' /etc/rc.local ", "delta": "0:00:00.007160", "end": "2014-08-13 09:45:18.660617", "item": "", "rc": 1, "start": "2014-08-13 09:45:18.653457"}

stdout: 0

...ignoring


TASK: [redis_install | Add Boot Start In Redhat Client] *********************** 

changed: [172.17.0.5]


TASK: [redis_install | Start Redis Service In Redhat Client] ****************** 

changed: [172.17.0.5]


TASK: [redis_install | Delete Redis compression Software In Redhat Client] **** 

changed: [172.17.0.5]


PLAY RECAP ******************************************************************** 

172.17.0.5                 : ok=11   changed=8    unreachable=0    failed=0   

real    0m12.757s

user    0m3.453s

sys 0m0.497s

9、查看redis master安装情况

09:48:39 # ssh 172.17.0.5

root@172.17.0.5's password: 

Last login: Wed Aug 13 09:45:28 2014 from 172.17.42.1

root@06762530db8c:~

09:48:43 # ps -ef|grep redis

root       294     1  0 09:45 ?        00:00:00 /usr/bin/redis-server/data/redis-2.6.17/conf/redis_6379.conf

root       343   329  0 09:48 pts/000:00:00 grepredis

root@06762530db8c:~

09:48:46 # cat /etc/rc.local 

#!/bin/sh

#

# This script will be executed *after* all the other init scripts.

# You can put your own initialization stuff in here if you don't

# want to do the full Sys V style init stuff.


touch/var/lock/subsys/local

/usr/bin/redis-server/data/redis-2.6.17/conf/redis_6379.conf

root@06762530db8c:~

09:48:52 # redis-cli -h 172.17.0.5 -p 6379

redis 172.17.0.5:6379> keys *

(empty list or set)

redis 172.17.0.5:6379>

10、安装redis slave

09:45:20 # time ansible-playbook redis_install.yml --extra-vars "host=172.17.0.6 user=root redis_master_ip=172.17.0.5 redis_master_port=6379" -k

SSH password: 


PLAY [172.17.0.6] ************************************************************* 


GATHERING FACTS *************************************************************** 

ok: [172.17.0.6]


TASK: [common | Install initializtion require software] *********************** 

changed: [172.17.0.6]


TASK: [redis_install | Copy Redis Software To Redhat Client] ****************** 

changed: [172.17.0.6]


TASK: [redis_install | Create Redis Install Dir] ****************************** 

ok: [172.17.0.6]


TASK: [redis_install | Uncompression Redis Software To Redhat Client] ********* 

changed: [172.17.0.6]


TASK: [redis_install | Copy Redis Config To Redhat Client] ******************** 

changed: [172.17.0.6]


TASK: [redis_install | Create Soft Link In Redhat Client] ********************* 

changed: [172.17.0.6] => (item=redis-cli)

changed: [172.17.0.6] => (item=redis-server)


TASK: [redis_install | Check Boot Start In Redhat Client] ********************* 

failed: [172.17.0.6] => {"changed": true, "cmd": "grep -c '/usr/bin/redis-server /data/redis-2.6.17/conf/redis_6379.conf' /etc/rc.local ", "delta": "0:00:00.006751", "end": "2014-08-13 09:49:07.569522", "item": "", "rc": 1, "start": "2014-08-13 09:49:07.562771"}

stdout: 0

...ignoring


TASK: [redis_install | Add Boot Start In Redhat Client] *********************** 

changed: [172.17.0.6]


TASK: [redis_install | Start Redis Service In Redhat Client] ****************** 

changed: [172.17.0.6]


TASK: [redis_install | Delete Redis compression Software In Redhat Client] **** 

changed: [172.17.0.6]


PLAY RECAP ******************************************************************** 

172.17.0.6                 : ok=11   changed=9    unreachable=0    failed=0   

real    1m48.579s

user    0m6.781s

sys 0m0.654s

11、查看redis slave安装情况

09:59:24 # ssh 172.17.0.6

root@172.17.0.6's password: 

root@dfec766fbaa7:~

09:59:28 # ll

total 0

root@dfec766fbaa7:~

09:59:31 # ps -ef|grep redis

root       197     1  0 09:49 ?        00:00:00 /usr/bin/redis-server/data/redis-2.6.17/conf/redis_6379.conf

root       227   212  0 09:59 pts/000:00:00 grepredis

09:59:49 # grep slave /data/redis-2.6.17/conf/redis_6379.conf |egrep -v "^#"

slaveof 172.17.0.5 6379

slave-serve-stale-data yes

slave-read-only yes

slave-priority 100

client-output-buffer-limit slave 256mb 64mb 60

root@dfec766fbaa7:~

10:00:09 # redis-cli -h 172.17.0.6 -p 6379

redis 172.17.0.6:6379> keys *

(empty list or set)

redis 172.17.0.6:6379> info

# Server

redis_version:2.6.17

redis_git_sha1:00000000

redis_git_dirty:0

redis_mode:standalone

os:Linux 2.6.32-431.17.1.el6.x86_64 x86_64

arch_bits:64

multiplexing_api:epoll

gcc_version:4.4.7

process_id:197

run_id:81207df2727abe534ae606afc0cb80016f75a422

tcp_port:6379

uptime_in_seconds:685

uptime_in_days:0

hz:10

lru_clock:280339


# Clients

connected_clients:2

client_longest_output_list:0

client_biggest_input_buf:0

blocked_clients:0


# Memory

used_memory:878072

used_memory_human:857.49K

used_memory_rss:7569408

used_memory_peak:877280

used_memory_peak_human:856.72K

used_memory_lua:31744

mem_fragmentation_ratio:8.62

mem_allocator:jemalloc-3.2.0


# Persistence

loading:0

rdb_changes_since_last_save:0

rdb_bgsave_in_progress:0

rdb_last_save_time:1407894548

rdb_last_bgsave_status:ok

rdb_last_bgsave_time_sec:-1

rdb_current_bgsave_time_sec:-1

aof_enabled:0

aof_rewrite_in_progress:0

aof_rewrite_scheduled:0

aof_last_rewrite_time_sec:-1

aof_current_rewrite_time_sec:-1

aof_last_bgrewrite_status:ok


# Stats

total_connections_received:1

total_commands_processed:70

instantaneous_ops_per_sec:0

rejected_connections:0

expired_keys:0

evicted_keys:0

keyspace_hits:0

keyspace_misses:0

pubsub_channels:0

pubsub_patterns:0

latest_fork_usec:0


# Replication

role:slave

master_host:172.17.0.5

master_port:6379

master_link_status:up

master_last_io_seconds_ago:1

master_sync_in_progress:0

slave_priority:100

slave_read_only:1

connected_slaves:0


# CPU

used_cpu_sys:0.24

used_cpu_user:0.10

used_cpu_sys_children:0.00

used_cpu_user_children:0.00


# Keyspace

可以从上面的Replication里看到主从做好了,信息如下图

img_2698a6bce37b562ee95b20faaf2758e3.jpe

然后去redis master里查看主从信息

img_5f7d6fdf349d90f37f6adb743d9da75f.jpe

12、redis 主从测试

A.redis master插入key

redis 172.17.0.5:6379> setmaster 1

OK

redis 172.17.0.5:6379> setslave 0

OK

redis 172.17.0.5:6379> get master

"1"

redis 172.17.0.5:6379> get slave

"0"

B.redis slave读取key

redis 172.17.0.6:6379> keys *

1) "master"

2) "slave"

redis 172.17.0.6:6379> get master

"1"

redis 172.17.0.6:6379> get slave

"0"

可以看到主从建立完成

下面是redis slave的日志情况

10:08:04 # cat /data/redis-2.6.17/log/redis_6379.log 

                _._                                                  

           _.-``__ ''-._                                             

      _.-``    `.  `_.  ''-._           Redis 2.6.17 (00000000/0) 64 bit

  .-`` .-```.  ```\/    _.,_ ''-._                                   

 (    '      ,       .-`  | `,    )     Running instand alone mode

 |`-._`-...-` __...-.``-._|'` _.-'|     Port: 6379

 |    `-._   `._    /     _.-'    |     PID: 197

  `-._    `-._  `-./  _.-'    _.-'

 |`-._`-._    `-.__.-'    _.-'_.-'|                                  

 |    `-._`-._        _.-'_.-'|           http://redis.io        

  `-._    `-._`-.__.-'_.-'_.-'                                   

 |`-._`-._    `-.__.-'    _.-'_.-'|                                  

 |    `-._`-._        _.-'_.-'|                                  

  `-._    `-._`-.__.-'_.-'_.-'                                   

      `-._    `-.__.-'    _.-'

          `-._        _.-'                                           

              `-.__.-'                                               


[197] 13 Aug 09:49:08.878 # Server started, Redis version 2.6.17

[197] 13 Aug 09:49:08.879 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.

[197] 13 Aug 09:49:08.879 * The server is now ready to accept connections on port 6379

[197] 13 Aug 09:49:09.879 * Connecting to MASTER 172.17.0.5:6379

[197] 13 Aug 09:49:09.879 * MASTER <-> SLAVE syncstarted

[197] 13 Aug 09:49:09.881 * Non blocking connect forSYNC fired the event.

[197] 13 Aug 09:49:09.881 * Master replied to PING, replication can continue...

[197] 13 Aug 09:49:10.035 * MASTER <-> SLAVE sync: receiving 18 bytes from master

[197] 13 Aug 09:49:10.035 * MASTER <-> SLAVE sync: Loading DB inmemory

[197] 13 Aug 09:49:10.035 * MASTER <-> SLAVE sync: Finished with success

[197] 13 Aug 10:04:56.980 * 1 changes in900 seconds. Saving...

[197] 13 Aug 10:04:56.982 * Background saving started by pid 233

[233] 13 Aug 10:04:57.226 * DB saved on disk

[233] 13 Aug 10:04:57.227 * RDB: 6 MB of memory used by copy-on-write

[197] 13 Aug 10:04:57.293 * Background saving terminated with success

13、删除redis安装

无论redis主从,删除都是一样的命令

09:57:32 # time ansible-playbook redis_delete.yml --extra-vars "host=172.17.0.5 user=root" -k

SSH password: 


PLAY [172.17.0.5] ************************************************************* 


GATHERING FACTS *************************************************************** 

ok: [172.17.0.5]


TASK: [redis_delete | Stop Redis Service In Redhat Client] ******************** 

changed: [172.17.0.5]


TASK: [redis_delete | Delete Redis Soft Line In Redhat Client] **************** 

changed: [172.17.0.5] => (item=redis-cli)

changed: [172.17.0.5] => (item=redis-server)


TASK: [redis_delete | Delete Redis Dir In Redhat Client] ********************** 

changed: [172.17.0.5]


TASK: [redis_delete | Delete Boot Start In Redhat Client] ********************* 

changed: [172.17.0.5]


PLAY RECAP ******************************************************************** 

172.17.0.5                 : ok=5    changed=4    unreachable=0    failed=0   



real    0m6.929s

user    0m1.942s

sys 0m0.250s

root@ip-10-10-10-10:/etc/ansible

10:09:18 # time ansible-playbook redis_delete.yml --extra-vars "host=172.17.0.6 user=root" -k

SSH password: 


PLAY [172.17.0.6] ************************************************************* 


GATHERING FACTS *************************************************************** 

ok: [172.17.0.6]


TASK: [redis_delete | Stop Redis Service In Redhat Client] ******************** 

changed: [172.17.0.6]


TASK: [redis_delete | Delete Redis Soft Line In Redhat Client] **************** 

changed: [172.17.0.6] => (item=redis-cli)

changed: [172.17.0.6] => (item=redis-server)


TASK: [redis_delete | Delete Redis Dir In Redhat Client] ********************** 

changed: [172.17.0.6]


TASK: [redis_delete | Delete Boot Start In Redhat Client] ********************* 

changed: [172.17.0.6]


PLAY RECAP ******************************************************************** 

172.17.0.6                 : ok=5    changed=4    unreachable=0    failed=0   

real    0m5.897s

user    0m1.726s

sys 0m0.258s

15、删除后测试

A.redis master上

10:09:55 # ifconfig

eth0      Link encap:Ethernet  HWaddr C6:3A:D2:D9:DD:D9  

          inet addr:172.17.0.5  Bcast:0.0.0.0  Mask:255.255.0.0

          inet6 addr: fe80::c43a:d2ff:fed9:ddd9/64Scope:Link

          UP BROADCAST RUNNING  MTU:1500  Metric:1

          RX packets:13236 errors:0 dropped:0 overruns:0 frame:0

          TX packets:12843 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:1000 

          RX bytes:26106313 (24.8 MiB)  TX bytes:906412 (885.1 KiB)


lo        Link encap:Local Loopback  

          inet addr:127.0.0.1  Mask:255.0.0.0

          inet6 addr: ::1/128Scope:Host

          UP LOOPBACK RUNNING  MTU:16436  Metric:1

          RX packets:196 errors:0 dropped:0 overruns:0 frame:0

          TX packets:196 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:0 

          RX bytes:9665 (9.4 KiB)  TX bytes:9665 (9.4 KiB)


root@06762530db8c:~

10:09:56 # ps -ef|grep redis

root       431   329  0 10:09 pts/000:00:00 grepredis

root@06762530db8c:~

10:09:59 # cat /etc/rc.local 

#!/bin/sh

#

# This script will be executed *after* all the other init scripts.

# You can put your own initialization stuff in here if you don't

# want to do the full Sys V style init stuff.


touch/var/lock/subsys/local

root@06762530db8c:~

10:10:01 # ll /data/

total 4

drwxr-xr-x 2 root root 4096 Jun  5 10:21 soft

root@06762530db8c:~

B. redis slave上

10:08:09 # ifconfig

eth0      Link encap:Ethernet  HWaddr BE:97:0C:B2:02:D9  

          inet addr:172.17.0.6  Bcast:0.0.0.0  Mask:255.255.0.0

          inet6 addr: fe80::bc97:cff:feb2:2d9/64Scope:Link

          UP BROADCAST RUNNING  MTU:1500  Metric:1

          RX packets:13062 errors:0 dropped:0 overruns:0 frame:0

          TX packets:12704 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:1000 

          RX bytes:25967216 (24.7 MiB)  TX bytes:842881 (823.1 KiB)


lo        Link encap:Local Loopback  

          inet addr:127.0.0.1  Mask:255.0.0.0

          inet6 addr: ::1/128Scope:Host

          UP LOOPBACK RUNNING  MTU:16436  Metric:1

          RX packets:86 errors:0 dropped:0 overruns:0 frame:0

          TX packets:86 errors:0 dropped:0 overruns:0 carrier:0

          collisions:0 txqueuelen:0 

          RX bytes:5288 (5.1 KiB)  TX bytes:5288 (5.1 KiB)


root@dfec766fbaa7:~

10:10:32 # ps -ef|grep redis

root       319   212  0 10:10 pts/000:00:00 grepredis

root@dfec766fbaa7:~

10:10:37 # cat /etc/rc.local 

#!/bin/sh

#

# This script will be executed *after* all the other init scripts.

# You can put your own initialization stuff in here if you don't

# want to do the full Sys V style init stuff.


touch/var/lock/subsys/local

root@dfec766fbaa7:~

10:10:39 # ll /data/

total 4

drwxr-xr-x 2 root root 4096 Jun  5 10:21 soft

root@dfec766fbaa7:~

如果大家想使用我的例子,可以从github里下载(地址是https://github.com/dl528888/ansible-examples/tree/master/redis_install),然后放到/etc/ansible目录里,下面是内容

img_0fa5f9ffa0f88744b57c219b4ec6b79a.jpe

转载自:http://blog.51cto.com/dl528888/1539251

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
1月前
|
Ubuntu API 网络虚拟化
ubuntu22 编译安装docker,和docker容器方式安装 deepseek
本脚本适用于Ubuntu 22.04,主要功能包括编译安装Docker和安装DeepSeek模型。首先通过Apt源配置安装Docker,确保网络稳定(建议使用VPN)。接着下载并配置Docker二进制文件,创建Docker用户组并设置守护进程。随后拉取Debian 12镜像,安装系统必备工具,配置Ollama模型管理器,并最终部署和运行DeepSeek模型,提供API接口进行交互测试。
352 15
|
1月前
|
网络协议 API Docker
Docker+consul容器服务的更新与发现
通过本文的介绍,我们详细探讨了如何结合Docker和Consul来实现容器服务的更新与发现。通过Consul的服务注册和发现功能,可以高效地管理和监控容器化服务,确保系统的高可用性和可扩展性。希望本文能帮助您在实际项目中更好地应用Docker和Consul,提高系统的可靠性和管理效率。
65 23
|
1月前
|
存储 NoSQL Redis
Docker 部署 Redis
在使用 Docker 部署 Redis 时,为实现数据持久化,需正确挂载容器内的数据目录到宿主机。推荐命令如下: ``` docker run -d --name redis -v /mnt/data/redis:/data -p 6379:6379 redis ``` 该命令将宿主机的 `/mnt/data/redis` 目录挂载到容器的 `/data` 目录,确保 Redis 数据持久化。此路径更通用,适合大多数场景。避免使用不匹配的挂载路径,如 `/var/lib/redis` 或 `/mnt/data/redis` 到非默认目录,以防止数据无法正确持久化。
|
2月前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
288 93
|
2月前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
79 17
|
2月前
|
运维 Java 虚拟化
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
137 12
|
2月前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
219 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
3月前
|
运维 网络安全 Python
自动化运维:使用Ansible实现批量服务器配置
在快速迭代的IT环境中,高效、可靠的服务器管理变得至关重要。本文将介绍如何使用Ansible这一强大的自动化工具,来简化和加速批量服务器配置过程。我们将从基础开始,逐步深入到更复杂的应用场景,确保即使是新手也能跟上节奏。文章将不包含代码示例,而是通过清晰的步骤和逻辑结构,引导读者理解自动化运维的核心概念及其在实际操作中的应用。
|
3月前
|
运维 Ubuntu 网络协议
自动化运维:使用Ansible进行服务器配置管理
在现代IT架构中,自动化运维已成为提升效率、减少人为错误的关键。本文将介绍如何使用Ansible这一强大的自动化工具来简化和标准化服务器的配置管理过程。通过具体的代码示例和操作步骤,我们将展示如何快速部署应用、管理配置以及自动化日常任务,从而确保环境的一致性和可靠性。
|
3月前
|
运维 Ubuntu 应用服务中间件
自动化运维之路:使用Ansible进行服务器管理
在现代IT基础设施中,自动化运维已成为提高效率和可靠性的关键。本文将引导您通过使用Ansible这一强大的自动化工具来简化日常的服务器管理任务。我们将一起探索如何配置Ansible、编写Playbook以及执行自动化任务,旨在为读者提供一条清晰的路径,从而步入自动化运维的世界。