sudo apt-get install build-essential libncurses5-dev cmake

sudo groupadd mysql

sudo useradd -g mysql mysql

sudo mkdir -p /data/mysql/

sudo mkdir -p /data/mysql/data/

wget http://mirrors.sohu.com/mysql/MySQL-5.7/mysql-5.7.9.tar.gz

tar -zxf mysql-5.7.9.tar.gz

sh BUILD/autorun.sh

# MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具,下面这个只是用来对比写cmake用的,并不能执行

./configure --prefix=/usr/local/mysql/ --localstatedir=/data/mysql/data --enable-assembler --without-isam --with-unix-socket-path=/data/mysql/data --enable-thread-safe-client --with-client-ldflags=-all-static --with-mysqld-ldflags=-all-static --with-plugins=partition,innobase --with-charset=utf8 --with-collation=utf8_general_ci --with-extra-charsets=utf8,gbk --with-big-tables --without-debug

# 要不要和apt-get安装一样,mysql放在 /var/lib/mysql/,sock放在 /var/run/mysqld/

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/data/mysql/data -DSYSCONFDIR=/etc -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_UNIX_ADDR=/var/run/mysql/mysql.sock -DMYSQL_TCP_PORT=3306 -DENABLED_LOCAL_INFILE=1 -DEXTRA_CHARSETS=utf8,gbk -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_PARTITION_STORAGE_ENGINE=1 -DWITH_EMBEDDED_SERVER=0

mysql5.7需要最新版的boost,如果提示:

-- Could not find (the correct version of) boost.

-- MySQL currently requires boost_1_59_0

到 http://www.boost.org 上面下载 boost_1_59_0.tar.gz

tar -zxvf boost_1_59_0.tar.gz

cd boost_1_59_0

# 编译生成boost的编译引擎

./bootstrap.sh

# 开始编译boost程序,这里需要十几分钟,没有进度条,不像make,蛋疼死了,完成后就代表安装成功了。

./bjam --prefix==./prefix/install

# 安装boost

./b2 install

# 回到mysql源码目录

cd ../mysql-5.7.9

# 开启4个线程编译

make -j4

# 安装

make install

如果到 53% 的时候出现错误:

make[2]: *** [storage/perfschema/unittest/pfs_connect_attr-t] Error 1

make[1]: *** [storage/perfschema/unittest/CMakeFiles/pfs_connect_attr-t.dir/all] Error 2

加上参数 -DWITH_EMBEDDED_SERVER=0

原因是它默认以嵌入式方式编译了:https://bugs.launchpad.net/percona-server/+bug/798050

The errors are in embedded which is not supported in Percona Server. Please try building with -DWITH_EMBEDDED_SERVER=OFF

Changed in percona-server:

status:New → Invalid

# 修改 mysql 安装目录和数据目录权限

sudo chown -R mysql:mysql /usr/local/mysql

sudo chown -R mysql:mysql /data/mysql/

cd /usr/local/mysql

sudo cp support-files/my-default.cnf /etc/my.cnf

sudo cp support-files/mysql.server /etc/init.d/mysqld

# 生成数据库数据

sudo /usr/local/mysql/bin/mysql_install_db --defaults-file=/etc/my.cnf --basedir=/usr/local/mysql --datadir=/data/mysql/data --user=mysql

# 配置环境变量,否则 mysql 客户端命令不可用

vim /etc/profile,在文件末尾添加

PATH=/usr/local/mysql/bin:$PATH

export PATH

source /etc/profile

# 修改密码:MySQL5.7在安装完后,第一次启动时,会在root目录下生产一个随机的密码,文件名为

.mysql_secret

cat /root/.mysql_secret

用得到的随机密码登陆,然后通过以下命令修改密码

SET PASSWORD = PASSWORD('new password');

不需要 flush privileges;


1. $ vim ~/.ctags

增加

alias phptags='ctags --langmap=php:.engine.inc.module.theme.php --php-kinds=cdf --languages=php'

2. $ vim ~/.ctags

写入

--regex-php=/^[ \t]*[(private|public|static)( \t)]*function[ \t]+([A-Za-z0-9_]+)[ \t]*\(/\1/f, function, functions/

--regex-php=/^[ \t]*[(private|public|static)]+[ \t]+\$([A-Za-z0-9_]+)[ \t]*/\1/p, property, properties/

--regex-php=/^[ \t]*(const)[ \t]+([A-Za-z0-9_]+)[ \t]*/\2/d, const, constants/

3. $ phptags -R


运行top后,按1可以看见每个CPU上的繁忙情况以及IOWAIT。

可是,我希望看到,到底哪个进程在哪个CPU上执行,到底是哪个进程导致IOWAIT很高。

认真看man top,终于找到方法:

执行top后,按f,按j,然后按空格退出,这样就出现一列#C,可以看见当前进程正在哪个CPU上执行了。

按W(大写的W),将top的配置写入配置文件,下次打开top的时候就能看见同样的配置了。

查看php进程运行在那个cpu上面

ps -eo pid,args:50,psr|grep worker.php


一、/dev/shm理论

默认的Linux发行版中的内核配置都会开启tmpfs,映射到了/dev/下的shm目录。可以通过df 命令查看结果.

/dev/shm/是linux下一个非常有用的目录,因为这个目录不在硬盘上,而是在内存里。因此在linux下,就不需要大费周折去建ramdisk,直接使用/dev/shm/就可达到很好的优化效果。默认系统就会加载/dev/shm ,它就是所谓的tmpfs,有人说跟ramdisk(虚拟磁盘),但不一样。象虚拟磁盘一样,tmpfs 可以使用您的 RAM,但它也可以使用您的交换分区来存储。而且传统的虚拟磁盘是个块设备,并需要一个 mkfs 之类的命令才能真正地使用它,tmpfs 是一个文件系统,而不是块设备;您只是安装它,它就可以使用了。

tmpfs有以下优势:

1。动态文件系统的大小,/dev /shm/需要注意的一个是容量问题,在linux下,它默认最大为内存的一半大小,使用df -h命令可以看到。但它并不会真正的占用这块内存,如果/dev/shm/下没有任何文件,它占用的内存实际上就是0字节;如果它最大为1G,里头放有 100M文件,那剩余的900M仍然可为其它应用程序所使用,但它所占用的100M内存,是绝不会被系统回收重新划分的

2。tmpfs 的另一个主要的好处是它闪电般的速度。因为典型的 tmpfs 文件系统会完全驻留在 RAM 中,读写几乎可以是瞬间的。

3。tmpfs 数据在重新启动之后不会保留,因为虚拟内存本质上就是易失的。所以有必要做一些脚本做诸如加载,绑定的操作。

二、修改/dev/shm大小

默认的最大一半内存大小在某些场合可能不够用,并且默认的inode数量很低一般都要调高些,这时可以用mount命令来管理它。

#mount -o size=1500M -o nr_inodes=1000000 -o noatime,nodiratime -o remount /dev/shm

在2G的机器上,将最大容量调到1.5G,并且inode数量调到1000000,这意味着大致可存入最多一百万个小文件。

如果需要永久修改/dev/shm的值,需要修改/etc/fstab

tmpfs /dev/shm tmpfs defaults,size=1.5G 0 0

mount -o remount /dev/shm

三、/dev/shm应用

首先在/dev/shm建个tmp文件夹,然后与实际/tmp绑定

mkdir /dev/shm/tmp

chmod 1777 /dev/shm/tmp

mount –bind /dev/shm/tmp /tmp(–bind )

  在使用mount –bind olderdir newerdir命令来挂载一个目录到另一个目录后,newerdir的权限和所有者等所有信息会发生变化。挂载后的目录继承了被挂载目录的所有属性,除了名称。Oracle 11g的amm内存管理模式就是使用/dev/shm,所以有时候修改MEMORY_TARGET或者MEMORY_MAX_TARGET会出现ORA-00845的错误


上传图片 出现错误:413 Request Entity Too Large

修改nginx.conf

http{
    client_max_body_size 10M; #添加 改大点
}

修改php.ini 中

upload_max_filesize = 10M
post_max_size = 10M