一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

生產(chǎn)環(huán)境中l(wèi)inux下的mysql安裝

 昵稱54185769 2018-06-26

寫在開頭的小故事:

很久以前小石頭我在一家公司做運(yùn)維工程師,當(dāng)時我們有一臺認(rèn)證服務(wù)器安裝了mysql5.5版本。有一天領(lǐng)導(dǎo)說防止它掛掉,做個主從復(fù)制吧,我開心的接受任務(wù),但是讓某同事聽到了,

此同事代號x,小x上來就是一波跟我裝x,跟我說我們還要用5.5版本的,5.5是最好的版本,安裝一定要用源碼安裝,這樣性能才是最佳的,還有一堆blablabla..........

總之我感覺沒一句是完全對的,我得出的結(jié)論是:You can you up , No can no bb................

下面我來寫我是怎么安裝mysql的,如果有哪些不對,歡迎指出。

 

step1:

下載mysql的安裝包,那么就有幾個問題了,如下:

下載什么平臺的mysql?

答:Linux版本,不管是centos還是debian我們都用Linux - Generic,也就是Linux上的通用版本。

用什么版本號的mysql?

答:5.5其實(shí)老了,有很多問題,盡量用新一點(diǎn)的,用5.6或5.7都行。

源碼安裝還是用官方編譯好的包?

答:都說源碼安裝定制度高,性能好,那我想問問你,你要定制哪些東西?性能提高多少?你不知道的話還是用官方編譯好的二進(jìn)制包吧。

不過聽說intel有個很好的c++編譯器,真的能提高性能,但是付費(fèi)的,沒用過。。。

去哪里下載mysql?

答:肯定是官網(wǎng)上,別在百度上亂找,官網(wǎng)地址:https://dev./downloads/mysql/

我們先來安裝5.6吧,我直接用wget下載,也可去官網(wǎng)點(diǎn)擊下載:

1
wget https://cdn.//Downloads/MySQL-5.6/mysql-5.6.39-linux-glibc2.12-x86_64.tar.gz

step2:

安裝過程:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
shell> yum install libaio                                         #安裝mysql的異步io庫,用于提高mysql性能
shell> yum install autoconf                                       #不安裝此包,則執(zhí)行scripts/mysql_install_db --user=mysql時可能會報錯
shell> mv mysql-5.6.39-linux-glibc2.12-x86_64.tar.gz /usr/local   #把我們剛下載的包移動到/usr/local目錄下
shell> tar -xf mysql-5.6.39-linux-glibc2.12-x86_64.tar.gz         #解壓包
shell> groupadd mysql                                             #創(chuàng)建mysql組
shell> useradd -r -g mysql -s /bin/false mysql                    #創(chuàng)建mysql用戶并屬于mysql組
shell> ln -s mysql-5.6.39-linux-glibc2.12-x86_64 mysql            #建立軟件鏈接
shell> cd mysql
shell> scripts/mysql_install_db --user=mysql
shell> bin/mysqld_safe --user=mysql &                             #通過mysql用戶啟動數(shù)據(jù)庫,執(zhí)行后回車即可
# Next command is optional
shell> cp support-files/mysql.server /etc/init.d/mysql.server     #這步是可選的,做一下比較好,這樣可以使用/etc/init.d/mysql.server start來啟動服務(wù)了
shell> chkconfig --add mysql.server                               #設(shè)置mysql開機(jī)自啟動
shell> echo "export PATH=/usr/local/mysql/bin:$PATH">>/etc/profile
shell> source /etc/profile                                        #這樣就可以直接打出mysql命令了,不用輸入/usr/local/bin/完整路徑

  

我們來驗(yàn)證一下是不是真的啟動了:

1
ps aux | grep mysql

我們看到了進(jìn)程號為24517的mysql進(jìn)程:

通過上面使用bin/mysqld_safe --user=mysql &方式啟動的mysql進(jìn)程,會自動監(jiān)控mysql進(jìn)程狀態(tài),如果mysql進(jìn)程意外死掉,則會被重新調(diào)起來:

看我們手動把它殺掉了,然后它又restart了。。。。

如果想關(guān)掉進(jìn)程,執(zhí)行下面命令:

1
mysqladmin shutdown

我們還可以用下面這種方式啟動,當(dāng)進(jìn)程意外退出時,不會被自動調(diào)起:

1
bin/mysqld --user=mysql &

上面兩種啟動方式了解就好,最佳做法是:

1
2
3
shell> cp support-files/mysql.server /etc/init.d/mysql.server
shell> chkconfig --add mysql.server
shell> /etc/init.d/mysql.server start|stop|status

  

程序可以正常啟動了,下面說說配置文件吧。

 

step3:

一個相對較優(yōu)的配置文件:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
[client]
[mysqld]
########basic settings########
server-id = 11
port = 3306
user = mysql
bind_address = localhost
#autocommit = 0            #使用這個配置文件進(jìn)行初始化時,一定要先把這行注掉,初始化完成后,去掉注釋,重啟數(shù)據(jù)庫生效,不然root連接不上數(shù)據(jù)庫。
character_set_server=utf8mb4
skip_name_resolve = 1
max_connections = 800
max_connect_errors = 1000
datadir = /data/mysql_data
transaction_isolation = READ-COMMITTED
explicit_defaults_for_timestamp = 1
join_buffer_size = 134217728
tmp_table_size = 67108864
tmpdir = /tmp
max_allowed_packet = 16777216
sql_mode = "STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION,NO_ZERO_DATE,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER"
interactive_timeout = 1800
wait_timeout = 1800
read_buffer_size = 16777216
read_rnd_buffer_size = 33554432
sort_buffer_size = 33554432
########log settings########
log_error = error.log
slow_query_log = 1
slow_query_log_file = slow.log
log_queries_not_using_indexes = 1
log_slow_admin_statements = 1
log_slow_slave_statements = 1
log_throttle_queries_not_using_indexes = 10
expire_logs_days = 90
long_query_time = 2
min_examined_row_limit = 100
########replication settings########
master_info_repository = TABLE
relay_log_info_repository = TABLE
log_bin = bin.log
sync_binlog = 1
gtid_mode = on
enforce_gtid_consistency = 1
log_slave_updates
binlog_format = row
relay_log = relay.log
relay_log_recovery = 1
binlog_gtid_simple_recovery = 1
slave_skip_errors = ddl_exist_errors
########innodb settings########
innodb_page_size = 8192
innodb_buffer_pool_size = 6G
innodb_buffer_pool_instances = 8
innodb_buffer_pool_load_at_startup = 1
innodb_buffer_pool_dump_at_shutdown = 1
innodb_lru_scan_depth = 2000
innodb_lock_wait_timeout = 5
innodb_io_capacity = 4000
innodb_io_capacity_max = 8000
innodb_flush_method = O_DIRECT
innodb_file_format = Barracuda
innodb_file_format_max = Barracuda
innodb_log_group_home_dir = /redolog/
innodb_undo_directory = /undolog/
innodb_undo_logs = 128
innodb_undo_tablespaces = 3
innodb_flush_neighbors = 1
innodb_log_file_size = 4G
innodb_log_buffer_size = 16777216
innodb_purge_threads = 4
innodb_large_prefix = 1
innodb_thread_concurrency = 64
innodb_print_all_deadlocks = 1
innodb_strict_mode = 1
innodb_sort_buffer_size = 67108864
########semi sync replication settings########
plugin_dir=/usr/local/mysql/lib/plugin
plugin_load = "rpl_semi_sync_master=semisync_master.so;rpl_semi_sync_slave=semisync_slave.so"
loose_rpl_semi_sync_master_enabled = 1
loose_rpl_semi_sync_slave_enabled = 1
loose_rpl_semi_sync_master_timeout = 5000
[mysqld-5.7]
innodb_buffer_pool_dump_pct = 40
innodb_page_cleaners = 4
innodb_undo_log_truncate = 1
innodb_max_undo_log_size = 2G
innodb_purge_rseg_truncate_frequency = 128
binlog_gtid_simple_recovery=1
log_timestamps=system
transaction_write_set_extraction=MURMUR32
show_compatibility_56=on

我們將使用上面的配置文件,對數(shù)據(jù)庫進(jìn)行重新初始化:

由于配置文件中指定了新的data目錄,所以我們把原來的干掉吧!

1
2
3
4
5
rm -rf /usr/local/mysql/data/
mkdir /redolog
mkdir /undolog
chown -R mysql:mysql /redolog
chown -R mysql:mysql /undolog

把上面的內(nèi)容寫到/etc/my.cnf中,然后重新執(zhí)行scripts/mysql_install_db --user=mysql初始化數(shù)據(jù)庫,可以看到新的data目錄已經(jīng)生成了:

1
2
[root@ip-172-31-23-178 mysql]# ls /data/mysql_data/
bin.index  error.log  mysql  test

別高興的太早!error.log里面的錯誤日志了解一下?

1
2
2018-04-10 09:14:20 29228 [Note] InnoDB: Initializing buffer pool, size = 6.0G
InnoDB: mmap(843055104 bytes) failed; errno 12

是的你猜的沒錯,我這機(jī)器硬盤一共就6G,滿了。。。那先改成1G

1
innodb_log_file_size = 1G

如果出錯了就自己看error.log具體問題具體分析,總有各種各樣的問題,初始化之前把/data/mysql_data等舊文件刪除,再重新初始化。

然后啟動數(shù)據(jù)庫:

1
2
[root@ip-172-31-23-178 mysql_data]# /etc/init.d/mysql.server start
Starting MySQL. SUCCESS!

然后把配置文件中的#autocommit = 0 去掉注釋,重啟數(shù)據(jù)庫讓此項生效。

如果初始化時沒把此項注釋,則你執(zhí)行mysql -uroot -p是連不上數(shù)據(jù)庫的,因?yàn)閿?shù)據(jù)庫時的user表中根本就沒有生成root用戶,在5.7中這個問題已經(jīng)沒有了。

最后mysql5.6中的test庫應(yīng)該刪除,因?yàn)樗遣话踩摹?/p>

 

 注意:

錯誤日志在哪里?

答:如果不在配置文件中指定, 則在/usr/local/mysql/data下會生成相應(yīng)的*.err文件。

報出data目錄沒有權(quán)限?

答:data目錄的權(quán)限應(yīng)該是mysql:mysql才對,如果之前系統(tǒng)安裝了mysql,則會在/etc/下存在舊的配置文件my.cnf,mysql會優(yōu)先讀取它,所以在安裝之前應(yīng)該將舊的配置文件干掉,免去不必要的麻煩。

使用上面的配置文件初始化數(shù)據(jù)庫,執(zhí)行mysql -uroot -p登錄不上?

答:上面說了,初始化之前把a(bǔ)utocommit = 0注釋掉,裝完了再打開,不然是生成不了root用戶的。mysql5.7版本無此問題。

標(biāo)簽: mysql安裝

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多

    丰满少妇高潮一区二区| 亚洲a码一区二区三区| 日本在线不卡高清欧美| 久草热视频这里只有精品| 日韩精品毛片视频免费看| 国产精品久久男人的天堂| 99久久精品一区二区国产| 欧美成人精品一区二区久久| 在线免费视频你懂的观看| 亚洲中文字幕在线观看黑人| 亚洲黄色在线观看免费高清| 内用黄老外示儒术出处| 久久精品a毛片看国产成人| 成年人黄片大全在线观看| 欧美日韩中国性生活视频| 亚洲精品一二三区不卡| 手机在线不卡国产视频| 国产一区二区三区香蕉av| 国产日韩欧美专区一区| 精品人妻少妇二区三区| 伊人天堂午夜精品草草网| 老司机激情五月天在线不卡| 久久久精品区二区三区| 亚洲综合天堂一二三区| 日本高清二区视频久二区| 国产av一区二区三区麻豆| 字幕日本欧美一区二区| 麻豆亚州无矿码专区视频| 国产高清视频一区不卡| 国产又色又爽又黄又大| 国产麻豆一线二线三线| 亚洲最新一区二区三区| 免费观看一区二区三区黄片| 一区二区福利在线视频| 久久99青青精品免费观看| 国产福利一区二区三区四区| 亚洲中文字幕综合网在线| 都市激情小说在线一区二区三区 | 亚洲天堂有码中文字幕视频| 欧美成人国产精品高清| 嫩草国产福利视频一区二区|