天天看點

LAMP_mysql配置mysql操作

<a href="http://s5.51cto.com/wyfs02/M00/85/78/wKiom1ekZMzQhhwNAAFsYlmnAzc784.png" target="_blank"></a>

以上mysql核心配置

二. mysql配置(部分常用的參數)

[mysqld]                        

socket = /tmp/mysql.sock     

# 為MySQL客戶程式與伺服器之間的本地通信指定一個套接字檔案(Linux下預設是/var/lib/mysql/mysql.sock檔案)

port             = 3306      

# 指定MsSQL偵聽的端口 

skip-name-resolve  

#禁止MySQL對外部連接配接進行DNS解析,使用這一選項可以消除MySQL進行DNS解析的時間。但需要注意,如果開啟該選項, 則所有遠端主機連接配接授權都要使用IP位址方式,否則MySQL将無法正常處理連接配接請求. 

key_buffer       = 384M      

# key_buffer是用于索引塊的緩沖區大小,增加它可得到更好處理的索引(對所有讀和多重寫)。索引被所有的線程共享,key_buffer的大小視記憶體大小而定。

table_open_cache      = 512       

# MySQL每打開一個表,都會讀入一些資料到table_open_cache緩存中,當MySQL在這個緩存中找不到相應資訊時,才會去磁盤上讀取。默 認值64, 假定系統有200個并發連接配接,則需将此參數設定為200*N(N為每個連接配接所需的檔案描述符數目);當把table_open_cache設定為很大時, 如果系統處理不了那麼多檔案描述符,那麼就會出現用戶端失效,連接配接不上.

max_allowed_packet = 4M   

# 接受的資料包大小;增加該變量的值十分安全,這是因為僅當需要時才會配置設定額外記憶體。例如,僅當你發出長查詢或MySQLd必須傳回大的結果行時 MySQLd才會配置設定更多記憶體。 該變量之是以取較小預設值是一種預防措施,以捕獲用戶端和伺服器之間的錯誤資訊包,并確定不會因偶然使用大的資訊包而導緻記憶體溢出。

sort_buffer_size = 2M        

# MySQL執行排序使用的緩沖大小。如果想要增加ORDER BY的速度,首先看是否可以讓MySQL使用索引而不是額外的排序階段。如果不能,可以嘗試增加sort_buffer_size變量的大小

read_buffer_size = 2M        

# 讀查詢操作所能使用的緩沖區大小。和sort_buffer_size一樣,該參數對應的配置設定記憶體也是每連接配接獨享。對表進行順序掃描的請求将配置設定一個讀入 緩沖區,MySQL會為它配置設定一段記憶體緩沖區。 如果對表的順序掃描請求非常頻繁,并且你認為頻繁掃描進行得太慢,可以通過增加該變量值以及記憶體緩沖區大小提高其性能.

join_buffer_size = 2M  

# 聯合查詢操作所能使用的緩沖區大小,和sort_buffer_size一樣,該參數對應的配置設定記憶體也是每連接配接獨享

query_cache_size = 32M       

# 指定MySQL查詢結果緩沖區的大小

read_rnd_buffer_size    = 2M 

# 随機讀緩沖區大小。當按任意順序讀取行時(例如,按照排序順序),将配置設定一個随機讀緩存區。進行排序查詢時,MySQL會首先掃描一遍該緩沖,以避免磁盤 搜尋,提高查詢速度,如果需要排序大量資料,可适當調高該值。但MySQL會為每個客戶連接配接發放該緩沖空間,是以應盡量适當設定該值,以避免記憶體開銷過大

myisam_sort_buffer_size =64M 

# MyISAM表發生變化時重新排序所需的緩沖

thread_concurrency      = 8 

# 最大并發線程數,取值為伺服器邏輯CPU數量×2

thread_cache            = 8 

#該值表示可以重新利用儲存在緩存中線程的數量,當斷開連接配接時若緩存中還有空間,那麼用戶端的線程将被放到緩存中,如果線程重新被請求,那麼請求将從緩存 中讀取,若果緩存中是空的或者是新的請求,那麼線程将被重新建立。設定規律為:1G記憶體設定為8,2G記憶體設定為16,4G以上設定為64

max_connections = 1000 

#MySQL的最大連接配接數,如果伺服器的并發連接配接請求量比較大,建議調高此值,以增加并行連接配接數量,當然這建立在機器能支撐的情況下,因為如果連接配接數越 多,介于MySQL會為每個連接配接提供連接配接緩沖區,就會開銷越多的記憶體,是以要适當調整該值,不能盲目提高設值。可以過'conn%'通配符檢視目前狀态的 連接配接數量,以定奪該值的大小。

max_connect_errors = 6000  

# 對于同一主機,如果有超出該參數值個數的中斷錯誤連接配接,則該主機将被禁止連接配接。如需對該主機進行解禁,執行:FLUSH HOST。

open_files_limit = 65535 

# MySQL打開的檔案描述符限制,預設最小1024

skip-locking                 

# 避免MySQL的外部鎖定,減少出錯幾率增強穩定性。 

wait_timeout  = 8  

# 表示空閑的連接配接逾時時間,預設是28800s,這個參數是和interactive_timeout一起使用的,也就是說要想讓wait_timeout 生效,必須同時設定interactive_timeout

interactive_timeout = 8

long_query_time = 1   

#慢查詢日志的逾時時間

log_slow_queries = /path/to/slow_queries  

# 慢查詢日志路徑,必須配合上面的參數一同使用

1. 忘記root密碼

編輯mysql主配置檔案 my.cnf 在[mysqld]字段下添加參數  skip-grant  ,重新開機資料庫服務,這樣就可以進入資料庫不用授權了 mysql -uroot ,修改相應使用者密碼 use mysql; update user set password=password('your password') where user='root';flush privileges;  最後修改/etc/my.cnf 去掉 skip-grant , 重新開機mysql服務

2. skip-innodb   我們可以增加這個參數不使用innodb引擎。

3. 配置慢查詢日志

#log_slow_queries = /path/to/slow_queries

#long_query_time = 1

4. mysql常用操作

檢視都有哪些庫  show databases;

檢視某個庫的表 use db; show tables; 

檢視表的字段 desc tb;

檢視建表語句 show create table tb;

目前是哪個使用者  select user();

目前庫 select database();

建立庫 create database db1; 

建立表 create table t1 (`id` int(4), `name` char(40));  

檢視資料庫版本 select version(); 

檢視mysql狀态 show status;

修改mysql參數 show variables like 'max_connect%'; set global max_connect_errors = 1000; 

檢視mysql隊列 show processlist; 

建立普通使用者并授權 grant all on *.* to user1 identified by '123456'; 

grant all on db1.* to 'user2'@'10.0.2.100' identified by '111222'; 

grant all on db1.* to 'user3'@'%' identified by '231222';insert into tb1 (id,name) values(1,'aming');

更改密碼 UPDATE mysql.user SET password=PASSWORD("newpwd") WHERE user='username' ;   

查詢 select count(*) from mysql.user; select * from mysql.db; select * from mysql.db where host like '10.0.%'; 

插入 update db1.t1 set name='aaa' where id=1;  

清空表 truncate table db1.t1; 

删除表 drop table db1.t1; 

删除資料庫 drop database db1; 

修複表 repair table tb1 [use frm];

5. mysql備份與恢複

備份 mysqldump -uroot -p db &gt;1.sql 

恢複 mysql -uroot -p db &lt;1.sql  

隻備份一個表  mysqldump -uroot -p db tb1 &gt; 2.sql

備份時指定字元集 mysqldump -uroot -p --default-character-set=utf8  db &gt;1.sql

恢複也指定字元集 mysql -uroot -p --default-character-set=utf8  db  &lt; 1.sql

擴充知識:

本文轉自 15816815732 51CTO部落格,原文連結:http://blog.51cto.com/68686789/1834839