摄影专区

当前位置:金沙7868com > 摄影专区 > 10下编译安装Memcached,源码编译安装配置方法图文

10下编译安装Memcached,源码编译安装配置方法图文

来源:http://www.jilawu.com 作者:金沙7868com 时间:2019-12-09 08:36

配置参数

  • 三脚架类型:相机安装连接座
  • 其他性能:头部安装板与六角螺栓, 3/8螺纹.
  • 外形设计:铝材料

查看完整参数>>

一、简介

安装环境:CentOS7 64位 MINI版

Memcached是国外社区网站 LiveJournal 的开发团队开发的高性能的分布式内存缓存服务器。一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度、提高可扩展性。

官网源码编译安装文档:

官方网站:

一、系统安装条件

二、原理

官方文档说明:

libevent是一套跨平台的事件处理接口的封装,能够兼容包括这些操作系统:Windows/Linux/BSD/Solaris 等操作系统的的事件处理。Memcached 使用libevent来进行网络并发连接的处理,能够保持在很大并发情况下,仍旧能够保持快速的响应能力。

1> cmake

1、数据存储方式:Slab Allocation

MySQL使用cmake跨平台工具预编译源码,用于设置mysql的编译参数。如:安装目录、数据存放目录、字符编码、排序规则等。安装最新版本即可。

Slab Allocator的基本原理是按照预先规定的大小,将分配的内存分割成特定长度的块,以完全解决内存碎片问题。

2> make3.75

Slab Allocation的原理相当简单。将分配的内存分割成各种尺寸的块(chunk),并把尺寸相同的块分成组(chunk的集合)

mysql源代码是由C和C++语言编写,在linux下使用make对源码进行编译和构建,要求必须安装make 3.75或以上版本

缺点:由于分配的是特定长度的内存,因此无法有效利用分配的内存。

3> gcc4.4.6

2、数据过期方式:Lazy Expiration

GCC是Linux下的C语言编译工具,mysql源码编译完全由C和C++编写,要求必须安装GCC4.4.6或以上版本

memcached内部不会监视记录是否过期,而是在get时查看记录的时间戳,检查记录是否过期。

4> Boost1.59.0

LRU——Least Recently Used,当memcached的内存空间不足时(无法从slab class 获取到新的空间时),就从最近未被使用的记录中搜索,并将其空间分配给新的记录。

mysql源码中用到了C++的Boost库,要求必须安装boost1.59.0或以上版本

三、安装

5> bison2.1

Memcache包括服务器和客户端的安装。可以在各种linux平台上安装,也可以在windows上安装。

Linux下C/C++语法分析器

服务器端

6> ncurses

    libevent
       官网:
       下载:
    Memcached
       官网:
       下载:

所以在安装前,需先安装相关的依赖库:

libevent安装

shell> sudo yum install -y cmake,make,gcc,gcc-c++,bison, ncurses,ncurses-devel

>tar -zxvf libevent-1.4.9-stable.tar.gz
>cd libevent-1.4.9-stable
>./configure      //默认装到/usr/lib/下
>make
>make install

下载Boost1.59.0源代码,并解压到/usr/local/目录下:

但是默认情况下,libevent是安装到了/usr/local/lib目录下,而memcached找ibevent-2.0.so.5模块的路径

shell> wget -O https://sourceforge.net/projects/boost/files/boost/1.59.0/boost_1_59_0.tar.gzshell> tar -zxvf boost_1_59_0.tar.gz -C /usr/local/

却是/usr/lib目录,可想而知,肯定找不到的啊,因此需要你软链接过去,或者你指定安装目录也行。

二、下载MySQL源码

ln -s  /usr/local/lib/libevent-2.0.so.5    /usr/lib/libevent-2.0.so.5

从github上下载mysql的源码

好了,到此为止,才算只真正的安装好了libevent.

shell> cd /optshell> git clone https://github.com/mysql/mysql-server.gitshell> ls mysql-server

     Memcached安装

如果没安装git客户端,执行yum install -y git安装。

>tar -zxvf memcached-1.4.1.tar.gz
>cd memcached-1.4.1
>./configure --prefix=/usr/local/memcached
>make
>make install
    Memcached启动

shell> git branch -rorigin/5.5origin/5.6origin/5.7origin/HEAD -> origin/5.7origin/cluster-7.2origin/cluster-7.3origin/cluster-7.4origin/cluster-7.5

>./memcached -d -m 10 -u root -l 10.20.20.194 -p 11210 -c 256 -P /tmp/memcached.pid

当前分支默认为5.7版本,如果要安装其它版本,切换到相应的分支即可。如安装5.6版本:git checkout 5.6,这里以安装5.7为例。

参数解释:
   -d 以守护程序(daemon)方式运行 memcached。

搜狐镜像下载地址:

   -u 指定用户,如果当前为 root 的话,需要使用此参数指定用户。
   -m 设置 memcached 可以使用的内存大小,单位为Mb,缺省是 64 MB;
   -l 设置监听的 IP 地址,如果是本机的话,通常可以不设置此参数;
   -p 设置监听的端口,默认为 11211,所以也可以不设置此参数;(此处不设置,测试后发现无法连接)

三、安装

   -c 设置最大运行的并发连接数,默认是1024

1> 添加mysql用户

   -P 设置保存Memcache的pid文件

shell> cd /opt/mysql-servershell> groupadd mysql #添加mysql用户组shell> useradd -r -g mysql -s /bin/false mysql #添加mysql用户

 

2> 配置mysql预编译参数

   Memcached停止

shell> cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DWITH_BOOST=/usr/local/boost_1_59_0 -DSYSCONFDIR=/etc -DEFAULT_CHARSET=utf8mb4 -DDEFAULT_COLLATION=utf8mb4_general_ci -DENABLED_LOCAL_INFILE=1 -DEXTRA_CHARSETS=all

>kill `cat /tmp/memcached.pid`

-DCMAKE_INSTALL_PREFIX:安装路径-DMYSQL_DATADIR:数据存放目录-DWITH_BOOST:boost源码路径-DSYSCONFDIR:my.cnf配置文件目录-DEFAULT_CHARSET:数据库默认字符编码-DDEFAULT_COLLATION:默认排序规则-DENABLED_LOCAL_INFILE:允许从本文件导入数据-DEXTRA_CHARSETS:安装所有字符集

备注:

更多预编译配置参数请参考mysql官方文档说明:

   cat /tmp/memcached.pid——查看memcached的进程号

3> 编译并安装

 

shell> make -j `grep processor /proc/cpuinfo | wc -l`shell> make install

   查看Memcached帮助信息

-j参数表示根据CPU核数指定编译时的线程数,可以加快编译速度。默认为1个线程编译,经测试单核CPU,1G的内存,编译完需要将近1个小时。

>./memcached -h

4> 初始化系统数据库

 

shell> cd /usr/local/mysqlshell> chown -R mysql:mysql .# 注意:MySQL 5.7.6之前的版本执行这个脚本初始化系统数据库shell> ./bin/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data# 5.7.6之后版本初始系统数据库脚本shell> ./bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/datashell> ./bin/mysql_ssl_rsa_setupshell> chown -R root .shell> chown -R mysql data

   检查Memcached是否运行正常

注意:如果使用–initialize参数初始化系统数据库之后,会在~/.mysql_secret文件中生成root用户的一个临时密码,同时也在初始化日志中打印出来了,如下图红圈中所示:

>ps auxxww | grep memcached

5、配置文件及参数优化

 

shell> cp support-files/my-default.cnf /etc/my.cnfshell> vim /etc/my.cnf[client]port=3306socket=/usr/local/mysql/mysql.sock[mysqld]character-set-server=utf8collation-server=utf8_general_ciskip-external-lockingskip-name-resolveuser=mysqlport=3306basedir=/usr/local/mysqldatadir=/usr/local/mysql/datatmpdir=/usr/local/mysql/temp# server_id = .....socket=/usr/local/mysql/mysql.socklog-error=/usr/local/mysql/logs/mysql_error.logpid-file=/usr/local/mysql/mysql.pidopen_files_limit=10240back_log=600max_connections=500max_connect_errors=6000wait_timeout=605800#open_tables=600#table_cache = 650#opened_tables = 630max_allowed_packet=32Msort_buffer_size=4Mjoin_buffer_size=4Mthread_cache_size=300query_cache_type=1query_cache_size=256Mquery_cache_limit=2Mquery_cache_min_res_unit=16ktmp_table_size=256Mmax_heap_table_size=256Mkey_buffer_size=256Mread_buffer_size=1Mread_rnd_buffer_size=16Mbulk_insert_buffer_size=64Mlower_case_table_names=1default-storage-engine=INNODBinnodb_buffer_pool_size=2Ginnodb_log_buffer_size=32Minnodb_log_file_size=128Minnodb_flush_method=O_DIRECT#####################thread_concurrency=32long_query_time=2slow-query-log=onslow-query-log-file=/usr/local/mysql/logs/mysql-slow.log[mysqldump]quickmax_allowed_packet=32M[mysqld_safe]log-error=/var/log/mysqld.logpid-file=/var/run/mysqld/mysqld.pid

  客户端

6、配置mysql服务

   a、linux安装

shell> cp support-files/mysql.server /etc/init.d/mysqldshell> chkconfig --add mysqld # 添加到系统服务shell> chkconfig mysqld on # 开机启动

         Memcached有两种安装方式:一种是直接安装memcache;一种是安装memcached。

7、启动服务

      (1)、安装memcache

shell> service mysqld start # 启动mysql服务shell> service mysqld stop # 停止mysql服务shell> service mysqld restart # 重新启动mysql服务

       PHP Memcache扩展

8、设置数据库密码

          官网:
          下载:

shell> /usr/local/mysql/bin/mysql -e "grant all privileges on *.* to root@'127.0.0.1' identified by "root" with grant option;"shell> /usr/local/mysql/bin/mysql -e "grant all privileges on *.* to root@'localhost' identified by "root" with grant option;"# 开启远程登录/usr/local/mysql/bin/mysql -e "grant all privileges on *.* to root@'%' identified by "root" with grant option;"

       安装

9、配置mysql环境变量

>tar -zxvf memcache-3.0.4.tgz
>cd memcache-3.0.4
>/usr/local/php/bin/phpize
>./configure --with-php-config=/usr/local/php/bin/php-config
>make
>make install

shell> vim /etc/profileshell> export PATH=/usr/local/mysql/bin:$PATHshell> source /etc/profile

        配置

四、其它注意事项

           在php.ini中新增配置内容:
           extension_dir = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/"
           extension = memcache.so

如果中途编译失败了,需要删除cmake生成的预编译配置参数的缓存文件和make编译后生成的文件,再重新编译。

 

shell> cd /opt/mysql-servershell> rm -f CMakeCache.txtshell> make clean

      (2)、安装memcached

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

            Memcached客户端是基于libmemcached的,所以需先安装libmemcached。

            libmemcached

               官网:

               下载:

            安装

>tar -zxvf libmemcached-0.33.tar.gz
>cd libmemcached-0.33
>./configure --prefix=/usr/local/libmemcached/ --with-libmemcached-dir=/usr/local/libmemcached/           --此处--with-libmemcached-dir需验证

>make
>make install

 

            PHP Memcached扩展

               官网:
               下载:

       安装

 

>tar -zxvf memcached-1.0.0.tgz
>cd memcached-1.0.0
>./configure --with-php-config=/usr/local/php/bin/php-config --with-libmemcached-dir=/usr/local/libmemcached/
>make
>make install
       配置

 

           在php.ini中新增配置内容:
           extension_dir = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/"
           extension = memcache.so

 

   b、Windows安装

       1、下载php_memcache.dll

       2、将php_memcache.dll拷贝到php/ext/目录下

       3、修改php.ini,加入extension=php_memcache.dll

       4、重启服务器
       5、检查phpinfo(),会发现memcache的部分

 

四、安装常见问题及解决

    1、现象:./memcached -h出现如下提示
              checking for libevent directory... configure: error: libevent is required.  You can get it from
        解决:在当前目录下,执行
              >whereis libevent
              >LD_金沙7868com ,DEBUG=libs ./memcached -v 2>&1 > /dev/null | less
              >ln -s /usr/src/libevent-1.4.9-stable/lib/libevent-1.4.so.2 /lib/

     2、现象:运行程序时,页面提示:Warning: Memcache::connect() [memcache.connect]: Can't connect to 10.20.20.194:11211, 由于连接方在一段时间后没有正确答复或连接的主机没有反应,连接尝试失败。 (10060) in E:AppServwwwtestmemcachetest1.php on line 4
       解决:设定端口,启动改为-p 11210
              >./memcached -d -m 10 -u root -l 10.20.20.194 -p 11210 -c 256 -P /tmp/memcached.pid

     3、现象:运行时提示:checking for libmemcached location... configure: error: memcached support requires libmemcached. Use --with-libmemcached-dir=<DIR> to specify the prefix where libmemcached headers and library are located

        解决:在当前目录下,执行whereis libmemcached找到libmemcached路径,然后添加选项--with-libmemcached-dir=libmemcached路径.

 

五、应用

<?php
//连接
$mem=new Memcache;
$mem->connect("10.20.20.194",11210);

//保存数据
$mem->set('key1','This is first value',0,60);
$val=$mem->get('key1');
echo "Get key1 value: ".$val
."<br>";

//替换数据
$mem->replace('key1','This is replace value',0,60);

$val=$mem->get('key1');
echo "Get key1 value: ".$val."<br>";

//保存数组
$arr=array('aaa','bbb','ccc','ddd');
$mem->set('key2',$arr,0,60);
$val2=$mem->get('key2');
echo "Get key2 value: ";
print_r($val2);
echo
"<br>";

//删除数据
$mem->delete('key1');
$val=$mem->get('key1');
echo "Get key1 value: ".$val."<br>";

//清除所有数据
$mem->flush();
$val2=$mem->get('key2');
echo "Get key2 value: ";
print_r($val2);
echo "<br>";

//关闭连接
$mem->close();
?>

六、Memcache方法说明
    1、Memcache::add — 添加一个值,如果已经存在,则���回false
    2、Memcache::addServer — 添加一个可供使用的服务器地址

       参数:

            第一个参数表示服务器的地址,

            第二个参数表示端口,

            第三个参数表示是否是一个持久连接,

            第四个参数表示这台服务器在所有服务器中所占的权重,

            第五个参数表示连接的持续时间,

            第六个参数表示连接重试的间隔时间,默认为15,设置为-1表示不进行重试,

            第七个参数用来控制服务器的在线状态,

            第八个参数允许设置一个回掉函数来处理错误信息。
    3、Memcache::close — 关闭一个Memcache对象
    4、Memcache::connect — 创建一个Memcache对象
    5、memcache_debug — 控制调试功能,前提是php在编译的时候使用了–enable-debug选项
    6、Memcache::decrement — 对保存的某个key中的值进行减法操作
    7、Memcache::delete — 删除一个key值

       参数:

            第一个参数表示key,

            第二个参数可选,表示删除延迟的时间。
    8、Memcache::flush — 清除所有缓存的数据,但是不会削去使用的内存空间。
    9、Memcache::get — 获取一个key值

       参数:

            一个参数,表示key
   10、Memcache::getExtendedStats — 获取进程池中所有进程的运行系统统计
   11、Memcache::getServerStatus — 获取运行服务器的参数

       参数:

            第一个参数表示服务器的地址,

            第二个参数表示端口
   12、Memcache::getStats — 返回服务器的一些运行统计信息

       参数:

           第一个参数表示要求返回的类型:reset, malloc, maps, cachedump, slabs, items, sizes;
           第二个参数和第三个参数是在第一个参数设置为“cachedump”时使用的。
   13、Memcache::getVersion — 返回运行的Memcache的版本信息
   14、Memcache::increment — 对保存的某个key中的值进行加法操作
   15、Memcache::pconnect — 创建一个Memcache的持久连接对象
   16、Memcache::replace — R对一个已有的key进行覆写操作

       参数:

            第一个参数是key,

            第二个参数是value,

            第三个参数可选,表示是否压缩保存,

            第四个参数可选,用来设置一个过期自动销毁的时间。

   17、Memcache::set — 添加一个值,如果已经存在,则覆写

       参数:

            第一个参数是key,

            第二个参数是value,

            第三个参数可选,表示是否压缩保存,

            第四个参数可选,用来设置一个过期自动销毁的时间。
   18、Memcache::setCompressThreshold — 对大于某一大小的数据进行压缩

       参数:

            第一个参数表示处理数据大小的临界点,

            第二个参数表示压缩的比例,默认为0.2。
   19、Memcache::setServerParams — 在运行时修改服务器的参数

       参数:

            第一个参数表示服务器的地址,

            第二个参数表示端口,

            第三个参数表示连接的持续时间,

            第四个参数表示连接重试的间隔时间,默认为15,设置为-1表示不进行重试,

            第五个参数用来控制服务器的在线状态,

            第六个参数允许设置一个回掉函数来处理错误信息。

金沙7868com 1

本文由金沙7868com发布于摄影专区,转载请注明出处:10下编译安装Memcached,源码编译安装配置方法图文

关键词: