亚洲视频二区_亚洲欧洲日本天天堂在线观看_日韩一区二区在线观看_中文字幕不卡一区

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.430618.com 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

目錄
  • 前言
  • 一、連接redis
  • 二、連接mysql
  • 三、tips
  • 總結(jié)

前言

當(dāng)我們?cè)谟胐ocker部署項(xiàng)目的時(shí)候可能會(huì)遇到這樣一個(gè)問(wèn)題:項(xiàng)目A和項(xiàng)目B都用到了redis和mysql,如果在docker-compose里link或者dependon一個(gè)redis和mysql的話,會(huì)發(fā)現(xiàn)每一個(gè)項(xiàng)目都有一個(gè)redis和mysql,這樣如果項(xiàng)目多了也會(huì)產(chǎn)生很多的redis和mysql,看著挺不爽而且也浪費(fèi)資源的,那能不能讓這些項(xiàng)目都能連同一個(gè)redis和mysql呢?

當(dāng)然是可以了,我們可以利用docker的自定義網(wǎng)絡(luò)實(shí)現(xiàn),或者將redis和mysql裝在宿主機(jī)上,所有的項(xiàng)目都連接宿主機(jī)的redis和mysql。

這里介紹的是第二種方法:將redis和mysql裝在宿主機(jī)上

看起來(lái)挺簡(jiǎn)單,只要在項(xiàng)目的配置文件里把連接redis和mysql的地址改成localhost就行了,但是這樣改部署完之后卻發(fā)現(xiàn)報(bào)錯(cuò)了,連接不上,這是因?yàn)椴荒芡ㄟ^(guò)localhost在docker容器里面連接宿主機(jī),接下來(lái)就需要做一點(diǎn)小小的配置了。

一、連接redis

1、在宿主機(jī)中輸入以下命令:

ifconfig

然后找到docker0這一行下面的inet 172.17.0.1,這個(gè)就是docker虛擬網(wǎng)卡的ip,通過(guò)這個(gè)ip,我們就可以在容器中連接宿主機(jī)了。

[root@VM-8-8-centos ~]# ifconfig
br-ffb2f3de993a: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 172.18.0.1  netmask 255.255.0.0  broadcast 172.18.255.255
        inet6 fe80::42:e9ff:fecd:eb0b  prefixlen 64  scopeid 0x20<link>
        ether 02:42:e9:cd:eb:0b  txqueuelen 0  (Ethernet)
        RX packets 32  bytes 2489 (2.4 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 38  bytes 2582 (2.5 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
docker0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
        inet 172.17.0.1  netmask 255.255.0.0  broadcast 172.17.255.255
        inet6 fe80::42:c1ff:fedc:e526  prefixlen 64  scopeid 0x20<link>
        ether 02:42:c1:dc:e5:26  txqueuelen 0  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 3  bytes 266 (266.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

2、找到redis的配置文件redis.conf,找到bind 127.0.0.1這一行,修改如下

bind 127.0.0.1 172.17.0.1

再找到# requirepass foobared 這行,取消注釋,并自行配置密碼,然后重啟redis

3、最后在項(xiàng)目中將連接redis的ip改成上面的172.17.0.1,并加上密碼即可

二、連接mysql

MySQL的跟Redis的就稍微有些不一樣了,Redis主要是對(duì)配文件進(jìn)行操作,而MySQL是要對(duì)表操作。

1、首先啟動(dòng)項(xiàng)目的容器,然后獲取ip

docker exec -it 容器id ip addr

然后找到eth0@if36開頭的這一行,下面的inet后的ip就是docker給容器的一個(gè)ip,我這里的是172.18.0.2

[root@VM-8-8-centos ~]# docker exec -it 8337cd4ab0a1 ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
35: eth0@if36: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue state UP 
    link/ether 02:42:ac:12:00:02 brd ff:ff:ff:ff:ff:ff
    inet 172.18.0.2/16 brd 172.18.255.255 scope global eth0
       valid_lft forever preferred_lft forever

2、登錄MySQL

# 一定要用root賬號(hào)
mysql -uroot -p密碼
# 指定數(shù)據(jù)庫(kù)
use mysql;

3、創(chuàng)建賬號(hào)并指定權(quán)限

# 這個(gè)命令的作用是:創(chuàng)建一個(gè)賬號(hào)symx,密碼12345678的用戶,指定只能由172.18.0.2的ip連接
CREATE user `symx`@'172.18.0.2' IDENTIFIED WITH mysql_native_password by '12345678';
# 這個(gè)命令的作用是:指定用戶symx,ip為172.18.0.2,該用戶可以對(duì)任意數(shù)據(jù)庫(kù)的任意表
# 進(jìn)行SELECT,INSERT,UPDATE,DELETE,CREATE,DROP操作,*.*的意思是:第一個(gè)*是數(shù)據(jù)庫(kù),
# 可以指定哪個(gè)數(shù)據(jù)庫(kù),*表示全部數(shù)據(jù)庫(kù);第二個(gè)*為表,可以指定是哪個(gè)表,*表示全部表
GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP on *.* TO `symx`@'172.18.0.2';
#當(dāng)然也可以給予賬號(hào)全部權(quán)限,下面和上面的命令只能選擇一個(gè),看個(gè)人的情況
GRANT ALL PRIVILEGES on *.* TO `symx`@`172.18.0.2`;
# 刷新
FLUSH PRIVILEGES;
# 執(zhí)行上面的命令可能會(huì)出現(xiàn)
# ERROR 1410 (42000): You are not allowed to create a user with GRANT的錯(cuò)誤,
# 這時(shí)可以執(zhí)行下面的命令,給予權(quán)限
GRANT system_user ON *.* TO 'root';
FLUSH PRIVILEGES;

4、以上都執(zhí)行成功后,就可以通過(guò)賬號(hào)symx,密碼12345678來(lái)連接數(shù)據(jù)庫(kù)了

需要注意的是:連接數(shù)據(jù)庫(kù)的ip為ifconfig的docker0的ip:172.17.0.1,而不是上面的容器里的ip。

三、tips

或許我們會(huì)有這樣一個(gè)疑問(wèn):為什么redis的配置文件里bind的是docker0的ip:172.17.0.1,而在mysql里的卻是docker容器的ip:172.18.0.2呢?

這是因?yàn)閞edis和mysql它們的策略不同。

首先講MySQL的策略,MySQL的策略就比較簡(jiǎn)單,在上面我們通過(guò)增加一個(gè)記錄在user表中指定了host和user這兩個(gè)字段,分別是ip和用戶名,即表示該賬號(hào)可以通過(guò)這個(gè)ip訪問(wèn)到mysql,這個(gè)ip指的是請(qǐng)求方的ip,而請(qǐng)求方的ip也就是docker容器內(nèi)的ip,即通過(guò)docker exec -it 容器id ip addr命令獲取到的ip。

而Redis就不一樣了,redis里的bind的意思是綁定本機(jī)的ip,準(zhǔn)確的說(shuō)是綁定本機(jī)的網(wǎng)卡對(duì)應(yīng)的ip地址,每個(gè)服務(wù)器都有多個(gè)網(wǎng)卡,每個(gè)網(wǎng)卡都有一個(gè)ip地址。網(wǎng)卡的ip地址,可以通過(guò)ifconfig命令查詢到,上面的172.17.0.1就是docker的網(wǎng)卡地址,所以bing:172.17.0.1意思是只允許來(lái)自docker這個(gè)網(wǎng)卡的請(qǐng)求,而不是說(shuō)只有請(qǐng)求方的ip為172.17.0.1才能訪問(wèn)。

在修改配置文件的時(shí)候,我們可以看到有一個(gè)配置是bind:127.0.0.1,這個(gè)綁定的是lo網(wǎng)卡的ip地址,也就是ifconfig命令下的lo那個(gè)地址,稱之為回環(huán)地址(Local Loopback),只有本地才能連接,默認(rèn)的配置文件只有這一個(gè)配置,所以做到了只有本地才能連接redis。

當(dāng)沒(méi)有指定bind的時(shí)候,則表示所有的ip都能訪問(wèn)到redis,通常不要這樣做,有很大幾率會(huì)被攻擊。

如果想限制只有指定的ip可以訪問(wèn)的話,還能通過(guò)防火墻來(lái)控制了,是不能通過(guò)redis的bind來(lái)限制的。

總結(jié)

分享到:
標(biāo)簽:容器 宿主 服務(wù)器 連接 配置
用戶無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定