每个人的声音都面向世界

木受绳则直,金就砺则利,君子博学而日参省乎己,则知明而行无过矣。

Yum配置笔记

YUM 优点

自动解决包的依赖性的问题能更新的添加/删除/更新/RPM包 便于管理大量系统的更新问题 可以同时配置多个资源库(Repository) 简洁的配置文件(/etc/yum.conf) 保持与RPM数据库的一致性 有一个比较详细的log.可以查看何时升级了什么软件包

CentOS的镜像站点

了解 镜像站点的文件结构 对理解 yum 配置文件 .repo 文件有帮助 http://mirror-status.centos.org http://isoredirect.centos.org/centos/5/isos/i386/ addons/ 本目录包含Centos的addons 仓库 centosplus/ 本目录包含Centos的centosplus 仓库 extras/ 本目录包含Centos的extras 仓库 fasttrack/ 本目录包含Centos的extras 仓库 isos-dvd/ 本目录包含发行版的DVD iso 下载 isos/ 本目录包含发行版 CD iso 下载 os/ 本目录包含发行版(distributions)的仓库 updates/ 本目录包含Centos的updates仓库

CentOS 的仓库

仓库(repository) 是一个预备好的目录or 网站,包含了软件包和索引。 yum 可以在仓库中自动定位并获取正确的RPM软件。 镜像服务器为每个版本的Centos分别提供了一些仓库。 Centos中的软件管理工具 yum已经预先配置为使用下列四个仓库: base: 构成Centos发行版(distributions)的软件包,和光盘上的内容相同 updates: base 仓库中软件包的更新版本 addons: 已编译的但不在发行版(distributions)中的软件包 extras: 一大批附加的软件包 centospuls: 用于增强一些现有软件包的功能(默认未启用)

CentOS 仓库的目录结构

updates/
 |--SRPMS                        #源代码目录
 |  |--*.src.rpm                #源代码包目录    
 |    |--repodata/                #源代码的索引文件
 |--i386                        #Intel 32位平台的目录
 |    |--RPMS                        #Intel 32位平台的RPMS目录
 |    |    |--*.i386.rpm            #在intel 32位平台上编译的包文件
 |    |    |--*.centos.noarch.rpm    #与平台无关的已编译的包文件
 |    |--repodata/                #intel 32位平台的索引文件
 |--x68_64                        #64位平台的目录
    |--RPMS                        #64位平台的RPMS目录
    |    |--x68_64.rpm            #在64位平台上编译的包文件
    |    |--*.centos.noarch.rpm    #与平台无关的已编译的包文件
    |--repodata/                #64位平台的索引文件

配置YUM客户的更新源

yum使用reposdir /etc/yum.repos.d 目录下的一系列.repo 文件列出可获取软件包仓库的镜像站点地址. 默认情况下有两个: Centos-Base.repo: 用于设置远程仓库 Centos-Media.repo: 用于设置本地仓库

yum 目录结构 /etc |–yum/ | |–/pluginconf.d
| |–/yum-updatesd.conf/ | |–downloadonly.conf | |–fastestmirror.conf | |–priorities.conf |–yum.conf |–yum.repos.d/ |–CentOS-Base.repo |–CentOS-Media.repo

在.repo 文件中,配置语法是分段的,每一段配置一个软件仓库,语法如下: 设置网络更新源 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [base] \用于指定仓库 name=CentOS-$releasever - Base \用于指定易读的仓库名称 mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os \用于指定本仓库的URL #baseurl=http://mirror.centos.org/centos/$releasever/os/$basearch/ # =ftp:// \用于指定远程ftp协议的愿 # =file:// \ 用于本地镜像或NFS挂载文件系统 #nabled=0/1 \用于指定是否使用本地仓库,默认为1,即可用。 gpgcheck=1 \用于指定是否检查软件包的GPG签名 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-5 \用于指定GPG签名文件的URL ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 注:若指定mirrorlist,系统将从Centos 的镜像站点中选择离你最近的仓库。 [$releasever]当前系统的版本号 [$basearch] 当前系统的构架 baseurl 可以指定多个URL ,系统会依次检查你列出的仓库。以便某个服务器宕机时使用另一台服务器

设置本地更新源

为了使用 [c5-media]仓库,需将Centos-Base ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [c5-media] name=CentOS-$releasever - Media baseurl=file:///media/CentOS/ file:///media/cdrom/ file:///media/cdrecorder/ gpgcheck=1 enabled=0 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-5 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

设置非官方更新源

以安置rpmforge 软件包为例在
http://rpm.pbone.net/
http://dag.wieers.com/rpm/
http://rpmforge.net
http://rpm.livna.org
http://freshrpms.net
http://atrpms.net
中找到适用于 Centos 5 的软件包
wget http://................rpmforge-release..... .rpm
rpm -ivh rpmforge-release........... .rpm
rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-rpmforge-*

安装 rpmforge-release 软件包之后可以看到/etc/yum.repos.d/rpmfoge.repo文件

or建立一个DAG 的仓库 vi /etc/yum.repos.d/dag.repo

[dag]
name=Dag RPM Repository for Red Hat Enterprise Linux
baseurl=http://apt.sw.be/redhat/el$releasever/en/$basearch/dag
gpgcheck=1
enabled=1
gpgkey=http://dag.wieers.com/packages/RPM-GPG-KYE.dag.txt

yum 命令工具

yum check-update            检查可更新的软件包
yum update                    下载更新系统已安装的所有软件把
yum upgrade                    大规模的升级,不同于上面的是,连旧的淘汰的包也升级
yum install <packages>        安装指定的软件包
yum update <packages>        更新指定的软件包
yum remove <packages>        卸载指定的软件包
yum groupinstall <packages>    安装指定的软件组中的软件包
yum groupupdate <packages>    更新 ... ...
yum groupremove <packages>    卸载 ... ...
yum grouplist                查看系统中已经安装的和可以用的软件组
yum list                    列出资源库中所有可以安装or 更新以及已经安装的的rpm包
yum list <regex>             列出资源库中与正则表达式匹配的可以安装或更新以及已经安装的rpm包
yum list available             列出资源库中所有可以安装的rpm包
yum list available <regex>     列出资源库中与正则表达式匹配的所有可以安装的rpm包
yum list updates             列出资源库中所有可以更新的rpm包
yum list updates <regex>     列出资源库中与正则表达式匹配的所有可以更新的rpm包
yum list installed             列出资源库中所有已经安装的rpm包
yum list installed <regex>     列出资源库中与正则表达式匹配的所有已经安装的rpm包
yum list extras             列出已经安装的但是不包含在资源库中的rpm包
yum list extras <regex>     列出与正则表达式匹配的已经安装的但是不包含在资源库中的rpm包
yum list recent             列出最近被添加到资源库中的软件包
yum search <regex>             检测所有可用的软件的名称、描述、概述和已列出的维护者,查找与正则表达式匹配的值
yum provides <regex>         检测软件包中包含的文件以及软件提供的功能,查找与正则表达式匹配的值
yum clean headers             清除缓存中的rpm头文件
yum clean packages             清除缓存中rpm包文件
yum clean all                 清除缓存中的rpm头文件和包文件
yum deplist <packages>         显示软件包的依赖信息

第一次使用yum或者yum资源库有更新是.yum会自动下载所有需要的headers 放置于/var/cache/yum 还可以用yum info 命令列出包信息,yum info 可用的参数与 yum list的相同 yum 命令还可以使用 -y 参数 回答命令运行时所提出的问题。

yum update 升级时 排除升级内核 yum update 排除升级内核,方法有两个: 1.修改yum的配置文件 vi /etc/yum.conf,在[main]的最后添加exclude=kernel 2.直接在yum的命令行执行如下的命令: yum –exclude=kernel update

附:

当仓库配置文件 *.repo 使用了多个URL yum-fastestmirror 可以自动选择最快的镜像站点 yum -y install yum-fastestmirror yum-fastestmirror 的配置文件在 /etc/yum/pluginconf.d/fastestmirror.conf 默认不需要修改。

yum -updatesd
rpm -ql yum-updatesd
yum -cron
yum -y install yum-cron
rpm -ql yum-cron
/etc
    |--/cron.daily/yum.cron        每日更新脚本
    |--/cron.weekly/yum.cron    每周更新脚本
    |--/rc.d/int.d/yum            启动脚本
    |--/yum/yum-daily.yum
/usr/share/doc/yum-cron-0.1
                        |--/COPYING
                        |--/README

使用yum下载而不安装rpm包 先安装yum-downloadonly # yum install yum-downloadonly

安装后使用方法如下: # yum update httpd -y –downloadonly ###下载到默认目录 /var/cache/yum OR # yum update httpd -y –downloadonly –downloaddir=/opt ##下载到指定目录 # yum install perl-MailTools –downloadonly –downloaddir=/opt -y ##如果软件已经下载过了,必须使用这个来下载

理解Mysql字符集设置

基本概念

  • 字符(Character)是指人类语言中最小的表义符号。例如’A’、’B’等;
  • 给定一系列字符,对每个字符赋予一个数值,用数值来代表对应的字符,这一数值就是字符的编码(Encoding)例如,我们给字符’A’赋予数值0,给字符’B’赋予数值1,则0就是字符’A’的编码;
  • 给定一系列字符并赋予对应的编码后,所有这些字符和编码对组成的集合就是字符集(Character Set)。例如,给定字符列表为{’A’,’B’}时,{’A’=>0, ‘B’=>1}就是一个字符集;
  • 字符序(Collation)是指在同一字符集内字符之间的比较规则;
  • 确定字符序后,才能在一个字符集上定义什么是等价的字符,以及字符之间的大小关系;
  • 每个字符序唯一对应一种字符集,但一个字符集可以对应多种字符序,其中有一个是默认字符序(Default Collation);
  • MySQL中的字符序名称遵从命名惯例:以字符序对应的字符集名称开头;以ci(表示大小写不敏感)、cs(表示大小写敏感)或_bin(表示按编码值比较)结尾。例如:在字符序“utf8_general_ci”下,字符“a”和“A”是等价的;

MySQL字符集设置

• 系统变量: – character_set_server:默认的内部操作字符集 – character_set_client:客户端来源数据使用的字符集 – character_set_connection:连接层字符集 – character_set_results:查询结果字符集 – character_set_database:当前选中数据库的默认字符集 – character_set_system:系统元数据(字段名等)字符集 – 还有以collation开头的同上面对应的变量,用来描述字符序。 • 用introducer指定文本字符串的字符集: – 格式为:[charset] ’string’ [COLLATE collation] – 例如: • SELECT latin1 ’string’; • SELECT utf8 ‘你好’ COLLATE utf8_general_ci; – 由introducer修饰的文本字符串在请求过程中不经过多余的转码,直接转换为内部字符集处理。

MySQL中的字符集转换过程

1. MySQL Server收到请求时将请求数据从character_set_client转换为character_set_connection;
2. 进行内部操作前将请求数据从character_set_connection转换为内部操作字符集,其确定方法如下:
    • 使用每个数据字段的CHARACTER SET设定值;
    • 若上述值不存在,则使用对应数据表的DEFAULT CHARACTER SET设定值(MySQL扩展,非SQL标准);
    • 若上述值不存在,则使用对应数据库的DEFAULT CHARACTER SET设定值;
    • 若上述值不存在,则使用character_set_server设定值。
3. 将操作结果从内部操作字符集转换为character_set_results。

understand-mysql-charset

常见问题解析

  • 向默认字符集为utf8的数据表插入utf8编码的数据前没有设置连接字符集,查询时设置连接字符集为utf8
  • 插入时根据MySQL服务器的默认设置,character_set_client、character_set_connection和character_set_results均为latin1;
  • 插入操作的数据将经过latin1=>latin1=>utf8的字符集转换过程,这一过程中每个插入的汉字都会从原始的3个字节变成6个字节保存;
  • 查询时的结果将经过utf8=>utf8的字符集转换过程,将保存的6个字节原封不动返回,产生乱码……

understand-mysql-charset

  • 向默认字符集为latin1的数据表插入utf8编码的数据前设置了连接字符集为utf8
  • 插入时根据连接字符集设置,character_set_client、character_set_connection和character_set_results均为utf8;
  • 插入数据将经过utf8=>utf8=>latin1的字符集转换,若原始数据中含有\u0000~\u00ff范围以外的Unicode字 符,会因为无法在latin1字符集中表示而被转换为“?”(0×3F)符号,以后查询时不管连接字符集设置如何都无法恢复其内容了。

understand-mysql-charset

检测字符集问题的一些手段

  • SHOW CHARACTER SET;
  • SHOW COLLATION;
  • SHOW VARIABLES LIKE ‘character%’;
  • SHOW VARIABLES LIKE ‘collation%’;
  • SQL函数HEX、LENGTH、CHAR_LENGTH
  • SQL函数CHARSET、COLLATION

使用MySQL字符集时的建议

  • 建立数据库/表和进行数据库操作时尽量显式指出使用的字符集,而不是依赖于MySQL的默认设置,否则MySQL升级时可能带来很大困扰;
  • 数据库和连接字符集都使用latin1时虽然大部分情况下都可以解决乱码问题,但缺点是无法以字符为单位来进行SQL操作,一般情况下将数据库和连接字符集都置为utf8是较好的选择;
  • 使用mysql C API时,初始化数据库句柄后马上用mysql_options设定MYSQL_SET_CHARSET_NAME属性为utf8,这样就不用显式地用 SET NAMES语句指定连接字符集,且用mysql_ping重连断开的长连接时也会把连接字符集重置为utf8;
  • 对于mysql PHP API,一般页面级的PHP程序总运行时间较短,在连接到数据库以后显式用SET NAMES语句设置一次连接字符集即可;但当使用长连接时,请注意保持连接通畅并在断开重连后用SET NAMES语句显式重置连接字符集。

其他注意事项

  • my.cnf中的default_character_set设置只影响mysql命令连接服务器时的连接字符集,不会对使用libmysqlclient库的应用程序产生任何作用!
  • 对字段进行的SQL函数操作通常都是以内部操作字符集进行的,不受连接字符集设置的影响。
  • SQL语句中的裸字符串会受到连接字符集或introducer设置的影响,对于比较之类的操作可能产生完全不同的结果,需要小心!