docker mysql容器使用-數據文件_配置文件掛載

mysql容器使用-數據文件_配置文件掛載

  • 下載鏡像
[root@silence ~]# docker pull docker.io/mysql:5.6

[root@silence ~]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
docker.io/mysql     5.6                 95e0fc47b096        11 days ago         257 MB
docker.io/mysql     latest              b8fd9553f1f0        11 days ago         445 MB
  • 觀察鏡像裏的配置文件目錄結構
[root@silence ~]# docker run --rm -it docker.io/mysql:5.6 /bin/bash
root@f5534c590a62:/# cd /etc/mysql/
root@f5534c590a62:/etc/mysql# ls
conf.d    my.cnf    my.cnf.fallback  mysql.cnf  mysql.conf.d
root@f5534c590a62:/etc/mysql# cd mysql.conf.d/
root@f5534c590a62:/etc/mysql/mysql.conf.d# ls
mysqld.cnf
root@f5534c590a62:/etc/mysql/mysql.conf.d# cat mysqld.cnf 

[mysqld]
pid-file    = /var/run/mysqld/mysqld.pid
socket        = /var/run/mysqld/mysqld.sock
datadir        = /var/lib/mysql
#log-error    = /var/log/mysql/error.log
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
root@f5534c590a62:/etc/mysql/mysql.conf.d# exit
exit
[root@silence ~]#
  • 準備一份5.6的可使用的配置文件
[mysqld]
pid-file    = /var/run/mysqld/mysqld.pid
socket        = /var/run/mysqld/mysqld.sock
datadir        = /var/lib/mysql
#log-error    = /var/log/mysql/error.log
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0

max_connections = 800    #指定mysql容許的最大鏈接進程數若是在訪問博客時常常出現 too many connections的錯誤 提示的話,則須要增大該參數的值。

max_connect_errors = 3000    #設置每一個主機的鏈接請求異常中斷的最大次數,當超過該次數時,MySQL服務器將禁止host的鏈接請求,直到MySQL服務器重啓或經過flush hosts命令來清空host的相關信息.

table_open_cache = 614   #用來指定表高速緩存的大小,當Mysql訪問一個表時,若是在mysql緩存區還有空間,那麼這個表就被打開並放入表緩衝區,這樣作的好處就是能夠更快速的訪問表中的內容,通常來講,能夠查看數據庫運行峯值時間的狀態值Open_tables和Open_tables,用以判斷是否須要增長table_open_cache的值,即若是Open_tables接近table_open_cache的時候,而且Opened_tables這個值在逐步增長,那就要考慮增長這個值的大小了。

external-locking = FALSE   #mysql選項能夠避免外部鎖定。True爲開啓。

max_allowed_packet =8M     #服務器一次能處理最大的查詢包的值,也是服務器程序可以處理的最大查詢。

sort_buffer_size = 1M   #設置查詢排序時所能使用的緩存區的大小,系統默認爲2M。

注意:該參數對應的分配內存是每一個鏈接獨佔的,若是有100個鏈接的話,那麼實際分配的總排序緩存區大小爲100x6=600M,因此,對於內存在4GB左右的服務器來講,推薦將其設置爲6MB~8MB。

join_buffer_size = 1M    #聯合查詢操做所能使用的緩存區大小,和sort_buffer_size同樣,該參數對應的分配內存也是每一個鏈接獨享的。

thread_cache_size = 100   #設置Thread Cache池中能夠緩存的鏈接線程最大數量,可設置爲0~16384,默認爲0,這個值表示能夠從新利用保存在緩存中線程的數量,當斷開鏈接時若是緩存中還有空間,那麼客戶端的線程將被放到緩存中,若是線程被從新請求,那麼請求將從緩存中讀取,若是緩存中是空的或者新的請求,那麼這個這個線程將被從新建立,若是有不少線程,增長這個值能夠改善系統性能,經過比較Connection和Thread_created狀態的數量,能夠看到這個變量的做用,咱們能夠根據物理內存設置規則以下:1GB內存咱們咱們配置8,2GB內存咱們配置爲16,3GB內存咱們配置爲32,4GB或4GB以上咱們給此值64或更大的值。

thread_concurrency = 2   #該參數取值爲服務器邏輯CPU數量x2。

query_cache_size = 2M    #指定mysql查詢緩衝區的大小,能夠經過在mysql控制檯觀察,若是qcache_lowmem_prunes的值很是大,則代表常常出現緩衝不夠的狀況,若是qcache_hits的值很是大,則代表查詢緩衝區使用的很是頻繁,另外若是改值較小反而會影響效率,那麼則能夠考慮不用查詢緩衝,對於acache_free_blocks,若是該值很是大,則代表緩衝區碎片不少。

query_cache_limit = 1M   #只有小於此設置值的結果纔會被緩存。

query_cache_min_res_unit = 2k  #設置查詢緩存分配內存的最小單位,要適當設置此參數,能夠作到爲減小內存快的申請和分配次數,可是設置過大可能致使內存碎片數值上升,默認值爲4K,建議設置W爲1K~16K。

default_table_type = InnoDB  #默認表的類型爲InnoDB。

thread_stack = 192K      #設置mysql每一個線程的堆棧大小,默認值足夠大,可知足普通操做,可設置範圍爲128K~4GB,默認爲192K.

transaction_isolation = READ-COMMITTED   #數據庫隔離級別(READ UNCOMMITTED(讀取未提交內容)READ  COMMITTED(讀取提交內容)REPEATABLE READ (可重讀)SERIALIZABLE(可串行化))

tmp_table_size = 2M    #設置內存臨時表最大值,若是超過該值,則會將臨時表寫入磁盤,其範圍1KB~4GB。

max_heap_table_size = 2M   #獨立的內存表所容許的最大容量

long_query_time = 1       #慢查詢的執行用時上限,默認爲10s,推薦1s~2s.

log_long_format  #沒有使用索引的查詢也會被記錄(推薦,根據業務來調整)

binlog_cache_size = 1M    #在一個事務中binlog爲了記錄SQL狀態所持有的Cache大小,若是常用大的,多聲明的事務,能夠增長此值來獲取更大的性能,全部從事務來的狀態都被緩衝在binlog緩衝中,而後再提交一次性寫入到binlog中,若是此事務比此值大,會使用磁盤上的臨時文件來替代,此緩衝在每一個連接的事務第一次更新狀態時被建立。

max_binlog_cache_size = 1M  #二進制日誌文件的最大長度(默認設置1GB),一個二進制文件信息超過了這個最大長度以前,MySQL服務器會自動提供一個新的二進制文件接上。

expire_logs_days = 7      #超過7天的binlog.mysql程序自動刪除(若是數據重要,建議不要開啓該選項)

key_buffer_size = 16M    #指定用於索引的緩衝區大小,增長它能夠獲得更好的索引處理性能,對於內存在4GB左右的服務器來講,該參數可設置爲256MB或384MB。

注意:若是該參數值設定的過大的話反而使服務器的總體效率下降。

read_buffer_size = 1M     #讀查詢操做所能使用的緩衝區大小,和sort_buffer_size同樣,該參數對應的分配內存也是每一個鏈接獨享。

read_rnd_buffer_size = 1M    #設置進行隨機讀的時候所使用的緩衝區,此參數和read_buffer_size所設置的Buffer相反,一個是順序讀的時候使用,一個是隨機讀的時候使用,可是二者都是針對與線程的設置,每一個線程均可以產生兩種Buffer中的任何一個,默認值256KB,最大值爲4GB。

bulk_insert_buffer_size = 1M   #若是常常性的須要使用批量插入放入特殊語句來插入數據,能夠適當調整參數至16MB~32MB,建議8MB。

 

lower_case_table_names = 1   #實現mysql不區分大小(開發需求,建議開啓)

skip-name-resolve    #禁止mysql對外部鏈接進行DNS解析,使用這一選項能夠消除mysql進行DNS解析的時候。可是須要注意的是,若是開啓該選項,則全部遠程主機鏈接受權都要使用IP地址方式了,不然mysql將沒法正常處理鏈接請求。

slave-skip-errors = 1032,1062   #從庫能夠跳過的錯誤數字值

replicate-ignore-db=mysql      #在作主從的狀況下,設置不須要同步的庫。

server-id = 6     #表示本機的序列號爲1,若是作主從或者多實例時,server-id必定不能相同

innodb_additional_mem_pool_size = 4M   #用來設置InnoDB存儲的數據目錄信息和其餘內部數據結構的內存池大小,應用程序裏的表越多,須要在這裏分配的內存越多,對於一個相對穩定的應用,這個參數的大小也是相對穩定的,也沒有必要預留很是大的值,若是InnoDB用光了這個池內的內存,InnoDB就開始從操做系統分配內存,而且往mysql錯誤日誌寫警告信息,默認爲1MB,當發現錯誤日誌中已經有相關的警告信息時,就應該適當的增長該參數的大小。

innodb_buffer_pool_size = 32M   #InnoDB使用一個緩衝池來保存索引和原始數據,設置越大,在存取表裏面數據時所須要的磁盤I/O 越少,通常設置爲物理內存的%25左右,注意:不要將InnoDB的Buffer pool值配置爲物理內存的50%~80%,應該根據具體生產環境而定。

innodb_data_file_path = ibdata1:128M:autoextend  #設置配置一個可擴展大小的尺寸爲128MB的單獨文件,名爲ibdata1,沒有給出文件的位置,全部默認的是在mysql的數據目錄內。

innodb_file_io_threads = 4     #InnoDB中的文件I/O線程,一般設置爲4,若是是Windows能夠設置更大的值以提升磁盤I/O.

innodb_thread_concurrency = 8     #服務器有幾個CPU就設置爲幾,建議用默認設置,通常設爲8。

innodb_flush_log_at_trx_commit = 2     #設置爲0就等於Innodb_log_buffer_size隊列滿後再統一存儲,默認爲1,也是最安全的設置。

innodb_log_buffer_size = 2M    #默認爲1MB,一般設置爲8~16MB就足夠了。

innodb_log_file_size = 4M    #肯定日誌文件的大小,更大的設置能夠提升性能,但也會增長恢復數據庫的時間。

innodb_log_files_in_group = 3     #爲提升性能,mysql能夠以循環方式將日誌文件寫入到多個文件。推薦設置爲3.

innodb_max_dirty_pages_pct = 90    #InnoDB主線程刷新緩存池中的數據。

innodb_lock_wait_timeout = 120    #InnoDB事務被回滾以前能夠等待一個鎖定的超時秒數,InnoDB在它本身的鎖定表中自動檢測事務死鎖而且回滾事務。InnoDB用lock tables語句注意到鎖定設置,默認值爲50秒。

innodb_file_per_table = 0   #InnoDB爲獨立表空間模式,每一個數據庫的每一個表都會生成一個數據空間。0爲關閉,1爲開啓。
我認可配置文件是我粘的,哈哈,配置文件能夠添加優化參數,可是不要更改路徑
  • 啓動容器
[root@silence ~]# docker run -d -p 3306:3306 --name mysql-silence_sean -e MYSQL_ROOT_PASSWORD=biubiubiuduang --privileged=true -v /data/conf/mysqld.cnf:/etc/mysql/mysql.conf.d -v /data/data:/var/lib/mysql/  docker.io/mysql:5.6
--privileged=true 使容器內擁有 root權限
-e MYSQL_ROOT_PASSWORD=biubiubiuduang 設置root 在「%」 密碼
-v /data/conf/mysqld.cnf:/etc/mysql/mysql.conf.d 掛載配置文件
設置環境變量
設置環境變量和鏡像的參數,能夠來解決第一個問題,環境變量使用-e的方式設置在鏡像名稱的前面;鏡像的參數須要配置在鏡像名稱的後面

docker run -d -p 4306:3306
-e MYSQL_USER="silence"
-e MYSQL_PASSWORD="sean"
-e MYSQL_ROOT_PASSWORD="rootpwd123"
--name mysql001
mysql/mysql-server
--character-set-server=utf8
--collation-server=utf8_general_ci
環境變量說明:

-e MYSQL_USER="silence":添加用戶silence
-e MYSQL_PASSWORD="sean":設置密碼:sean
-e MYSQL_ROOT_PASSWORD="rootpwd123":設置root的密碼:rootpwd123

鏡像參數說明:

--character-set-server=utf8:設置字符集爲utf8
--collation-server=utf8_general_ci:設置字符比較規則爲utf8_general_ci
相關文章
相關標籤/搜索