Docker容器連接外部Mysql的幾種方案
前言
在Linux Centos上面部署Docker容器,并且將原來的項目服務(wù)放到docker的某個鏡像中,啟動服務(wù)號發(fā)現(xiàn)無法連接到容器所在宿主機(jī)的mysql數(shù)據(jù)庫,但是現(xiàn)在項目服務(wù)需要連接mysql數(shù)據(jù)庫。
例如:SQLalchemy
# 初始化數(shù)據(jù)庫連接: TODO 參數(shù)化 engine = create_engine( f'mysql+mysqlconnector://{DB_USERNAME}:{DB_PASSWORD}@{DB_HOST}:{DB_PORT}/{DB_NAME}') # 創(chuàng)建DBSession類型: DBSession = sessionmaker(bind=engine) # 創(chuàng)建session對象: session = DBSession()
但是在容器中項目localhost默認(rèn)的是docker容器這個虛擬主機(jī)的ip,而我在docker該鏡像容器中上面并沒有安裝mysql服務(wù),
方案一:
使用宿主機(jī)的ip地址,docker有自己的ip,宿主機(jī)所在的Centos服務(wù)器也有自己的ip,如果把項目訪問IP改為宿主機(jī)的ip。
輸入ifconfig
替換上面的項目中訪問mysql的地址即 localhost 替換好了之后啟動容器。這是土辦法,但遇到ip變動的window就不太可行。
方案二:
在docker配置文件yml中設(shè)置參數(shù)command
docker-compose.yml version: '3' services: mysql: restart: always image: mysql:5.7 container_name: mysql command: --default-authentication-plugin=mysql_native_password #解決外部無法訪問 volumes: - ./mydir:/mydir - ./datadir:/var/lib/mysql - ./conf/my.cnf:/etc/my.cnf # 數(shù)據(jù)庫還原目錄 可將需要還原的sql文件放在這里 - /docker/mysql/source:/docker-entrypoint-initdb.d environment: - MYSQL_ROOT_PASSWORD=password - TZ=Asia/Shanghai ports: - 3306:3306
方案三:
如果mysql是非docker容器化部署,可以進(jìn)行掛載外部mysql
docker run -p 3306:3306 --name mysql \ -v /usr/local/docker/mysql/conf:/etc/mysql \ -v /usr/local/docker/mysql/logs:/var/log/mysql \ -v /usr/local/docker/mysql/data:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORD=123456 \ -d mysql:5.7
配置my.cnf信息
[mysqld] # 服務(wù)端字符集 character-set-server=utf8 collation_server = utf8_general_ci [client] # 客戶端字符集 default-character-set=utf8
另有網(wǎng)友提供
找到my.cnf配置文件
注釋掉 bind-address = 127.0.0.1,
重啟mysql
總結(jié)
到此這篇關(guān)于Docker容器連接外部Mysql的幾種方案的文章就介紹到這了,更多相關(guān)Docker容器連接外部Mysql內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何在docker中運(yùn)行springboot項目過程圖解
這篇文章主要介紹了如何在docker中運(yùn)行springboot項目過程圖解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-06-06詳解Docker中安裝配置Oracle數(shù)據(jù)庫
本篇文章主要介紹了詳解Docker中安裝配置Oracle數(shù)據(jù)庫,具有一定的參考價值,有興趣的可以了解一下。2017-04-04解決docker啟動容器錯誤:docker:Error response from dae
這篇文章主要介紹了解決docker啟動容器錯誤:docker:Error response from daemon:OCI runtime create failed問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05Docker.v19安裝和配置Docker Compose編排工具的方法
這篇文章主要介紹了安裝Docker.v19和配置Docker Compose編排工具的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2020-06-06