centos 源码mysql,centos开源吗
Ubuntu编译MySQL5
解决Ubuntu编译MySQL5源码时遇到的"找不到curses/termcap库"问题,关键在于确保系统已经正确安装了libncurses5-dev。此库在CentOS环境下可能已自动安装,但在Ubuntu中,需要手动执行指令安装。具体步骤如下:
首先,确认是否已安装libncurses5-dev:
在Ubuntu中使用指令
./configure–with-named-curses-libs=/usr/lib/libncurses.so.5
此行命令用于指定编译时使用特定的libncurses库版本。然而,为了简化此过程,推荐在编译前先解决libncurses5-dev的缺失问题。
解决方法如下:
使用
sudo apt-get install libncurses5-dev
指令安装libncurses5-dev。
安装完成后,重新执行编译步骤,通常无需手动指定lib路径,系统会自动识别并使用正确的库。
编译MySQL5源码的具体步骤如下:
1.使用
sudo groupadd mysql
创建名为mysql的用户组。
2.使用
sudo useradd-g mysql mysql
创建名为mysql的用户,并将该用户添加到之前创建的mysql组中。
3.解压缩并解压MySQL源码包。
4.进入解压后的目录并执行编译配置:
./configure–prefix=/usr/local/webserver/mysql/–enable-assembler–with-extra-charsets=complex–enable-thread-safe-client–with-big-tables–with-readline–with-ssl–with-embedded-server–enable-local-infile–with-plugins=innobase
5.执行编译并安装:
make&& make install
6.调整文件权限:
chmod+w/usr/local/webserver/mysql
7.更改文件所有权:
chown-R mysql:mysql/usr/local/webserver/mysql
完成上述步骤后,MySQL5在Ubuntu环境下应能成功编译并安装,无需额外指定库路径。
linux下安装mysql,求助大侠们
3. MySQL的安装
MySQL有两种安装方式:源码包安装和二进制包安装。这两种方式各有特色:二位制包安装不需编译,针对不同的平台有经
过优化编译的不同的二进制文件以及包格式,安装简单方便;源码包则必须先配置编译再安装,可以根据你所用的主机环境进行优化,选择最佳的配置值,安装定制
更灵活。下面分别介绍这两种安装方式。
3.1源码包方式安装
3.1.1在linux系统中添加运行Mysql的用户和组
/usr/sbin/groupadd mysql
/usr/sbin/useradd-d/var/lib/mysql-s/sbin/nologin-g mysql mysql
3.1.2下载最新稳定发行版(GA)的MySQL软件
访问MySQL网站下载最新稳定发行版的MySQL源码包。本文使用的是5.0.51版本,在linux系统下用下面的命令下载:
wget
3.1.3解压缩下载的源码包
首先建立一个工作目录(笔者建议的目录为/usr/local/src/mysql):
mkdir-p/usr/local/src/mysql
将下载的源码包移至工作目录:
mv mysql-5.0.51.tar.gz/usr/local/src/mysql
进入工作目录并用tar命令解压源码包:
cd/usr/local/src/mysql
tar zxvf mysql-5.0.51.tar.gz
命令执行结束后,当前工作目录下将生成一个新的子目录mysql-5.0.51,此目录下即为mysql的源码文件。
3.1.4配置Makefile文件
进入MySQL源码目录:
cd mysql-5.0.51
执行下面的命令可查看可配置选项:
./configure--help
本文使用的配置命令格式如下:
CC=gcc CFLAGS="-O3" CXX=gcc CXXFLAGS="-O3-felide-constructors
-fno-exceptions-fno-rtti"./configure
--prefix=/usr/local/mysql--enable-thread-safe-client--enable-assembler
--with-big-tables--with-client-ldflags=-all-static
--with-mysqld-ldflags=-all-static--with-charset=utf8
--with-collation=utf8_general_ci--with-extra-charsets=complex
配置选项说明:
CC:C编译器的名称(用于运行configure),本文示例为gcc
CFLAGS:C编译器的标志(用于运行configure),本文示例为-O3,指定优化级别为3
CXX:C++编译器的名称(用于运行configure),本文示例为gcc
CXXFLAGS:C++编译器的标志(用于运行configure)
--prefix:指定安装目录,本文示例为/usr/local/mysql
--localstatedir:指定默认数据库文件保存目录,默认为安装目录下的var目录
--enable-thread-safe-client:编译线程安全版的MySQL客户端库
--enable-assembler:使用一些字符函数的汇编版本
--with-client-ldflags:客户端链接参数,本文示例为指定静态编译mysql客户端
--with-mysqld-ldflags:服务器端链接参数,本文示例为指定静态编译mysql服务器
--with-big-tables:在32位平台上支持大于4G行的表
--with-charset:指定默认字符集。mysql默认使用latin1(cp1252)字符集,可以使用此选项更改。字符集可以是big5、
cp1251、cp1257、czech、danish、dec8、dos、euc_kr、gb2312、gbk、german1、hebrew、
hp8、hungarian、koi8_ru、koi8_ukr、latin1、latin2、sjis、swe7、tis620、ujis、usa7或
win1251ukr。
--with-collation:指定默认校对规则。mysql默认使用latin1_swedish_ci校对规则,可以使用此选项更改。
--with-extra-charsets:服务器需要支持的字符集,有三种可能的值:空格间隔的一系列字符集名;complex,包括不能动态装载的所有字符集;all,将所有字符集包括进二进制。本文示例为complex。
注意:要想更改字符集和校对规则,要同时使用--with-charset和--with-collation选项。校对规则必须是字符集的合法校对规则。(在mysql中使用SHOW COLLATION语句来确定每个字符集使用哪个校对规则)。
3.1.5编译源代码
执行下面的命令编译源代码:
make
3.1.6安装
执行下面的命令安装mysql到目标路径:
make install
3.1.7复制默认全局启动参数配置文件到/etc目录
源
码方式安装需要手动复制配置文件,配置模板位于源码树的support-files目录,有my-small.cnf、my-medium.cnf、
my-large.cnf、my-huge.cnf四个,选择跟你的环境相接近的一个复制到/etc目录,并做适当修改。关于mysql配置文件的详细信
息请参阅笔者的其它文章或是mysql官方文档。
本文示例选择my-medium.cnf,执行下面的命令将其复制到/etc目录:
cp./support-files/my-medium.cnf/etc/my.cnf
3.1.8初始化授权表
执行下面的命令初始化授权表:
./scripts/mysql_install_db--user=mysql
3.1.9更改mysql数据目录属主和权限
默认数据库文件保存目录为安装目录下的var目录,执行configure命令时可通过--localstatedir参数指定不同的目录,本文示例为默认位置。
chown-R mysql.mysql/usr/local/mysql/var
chmod-R 700/usr/local/mysql/var
3.1.10设置开机自启动服务控制脚本
执行下面的命令复制启动脚本到资源目录:
cp./support-files/mysql.server/etc/rc.d/init.d/mysqld
执行下面的命令增加mysqld服务控制脚本执行权限:
chmod+x/etc/rc.d/init.d/mysqld
执行下面的命令将mysqld服务加入到系统服务:
chkconfig--add mysqld
执行下面的命令检查mysqld服务是否已经生效:
chkconfig--list mysqld
命令输出类似下面的结果:
mysqld 0:off 1:off 2:on 3:on 4:on 5:on 6:off
表明mysqld服务已经生效,在2、3、4、5运行级别随系统启动而自动启动,以后可以使用service命令控制mysql的启动和停止。
启动mysqld服务:
service mysqld start
停止mysqld服务:
service mysqld stop
执行下面的命令关闭开机自启动:
chkconfig mysqld off
执行下面的命令可以改变开机自启动的运行级别为3、5:
chkconfig--level 35 mysqld on
3.1.11将mysql的bin目录加入PATH环境变量
编辑/etc/profile文件:
vi/etc/profile
在文件最后添加如下两行:
PATH=$PATH:/usr/local/mysql/bin
export PATH
执行下面的命令使所做的更改生效:
./etc/profile
3.2二进制包方式安装
3.2.1从安装媒体安装
Mysql二进制包已经包含在CentOS 5的安装媒体中,可以直接从安装媒体中安装下面三个rpm包:
mysql-5.0.22-2.1.0.1.i386.rpm
mysql-devel-5.0.22-2.1.0.1.i386.rpm
mysql-server-5.0.22-2.1.0.1.i386.rpm
不同的版本文件名有所不同,请注意区分。
执行下面的命令安装:
rpm-iUvh mysql-5.0.22-2.1.0.1.i386.rpm
rpm-iUvh mysql-devel-5.0.22-2.1.0.1.i386.rpm
rpm-iUvh mysql-server-5.0.22-2.1.0.1.i386.rpm
3.2.2通过yum安装
如果你安装的机器此时可以连接到互联网,笔者建议使用yum命令来简化安装过程:
yum install mysql-server mysql-devel mysql
yum将自动从centos的镜像站点查找你指明的软件的最新二进制包,并检查软件包依赖关系,安装软件的同时自动安装其依赖的软件包。
3.2.3从mysql网站下载最新稳定版本的二进制包安装
通过CentOS安装媒体或yum安装的二进制包版本会落后于mysql开发者网站发布的版本,可以从mysql网站下载安装最新稳定版本的mysql。
访问MySQL网站下
载最新稳定发行版的相应硬件平台的MySQL。本文使用的是Red Hat Enterprise Linux 5 RPM(x86)
5.0.45版本。需要下载Server、Client、Headers and Libraries、Share Libraries/Shared
compatibility libraries几个rpm包,其它为可选包,按需要选择。
在linux系统下用下面的命令下载:
wget
wget
wget
wget
wget
执行下面的命令安装:
rpm-iUvh MySQL-server-community-5.0.45-0.rhel5.i386.rpm
rpm-iUvh MySQL-client-community-5.0.45-0.rhel5.i386.rpm
rpm-iUvh MySQL-devel-community-5.0.45-0.rhel5.i386.rpm
rpm-iUvh MySQL-shared-community-5.0.45-0.rhel5.i386.rpm
rpm-iUvh MySQL-shared-compat-5.0.45-0.rhel5.i386.rpm
4. MySQL的配置
4.1目录结构
4.1.1源码包方式安装目录结构
源码包方式安装时通常是在3.1.4节中configure命令的--prefix选项指定的目录中建立如下的目录结构,特殊指定的目录除外:
./bin#mysql用户可执行文件目录
./include/mysql#mysql C头文件目录
./info#mysql信息文件目录
./lib/mysql#mysql库文件目录
./libexec#mysql后台daemon程序目录
./man#mysql联机帮助文档目录
./mysql-test#mysql测试程序目录
./share/mysql#mysql公用文件目录,包括字符集、配置文件模板、启动脚本、初始化SQL文件等
./sql-bench#mysql压力测试程序目录
/etc/my.cnf#mysql配置文件
/etc/rc.d/init.d/mysqld#mysqld服务启动脚本
4.1.2 RPM二进制包方式安装目录结构
二进制包方式安装时使用系统软件默认目录结构:
/usr/bin#mysql用户可执行文件目录
/usr/libexec#mysql后台daemon程序目录
/usr/lib/mysql#mysql库文件目录
/usr/lib64/mysql#如果为64系统,mysql 64位库文件目录
/usr/share/doc#mysql文档目录
/usr/share/info#mysql信息文件目录
/usr/share/man#mysql联机帮助文档目录
/usr/share/mysql#mysql字符集目录
/usr/include/mysql#mysql C头文件目录
/var/log#mysqld服务日志文件目录
/var/run/mysqld#mysqld服务运行状态目录
/var/lib/mysql#mysql数据文件目录
/etc/my.cnf#mysql配置文件
/etc/rc.d/init.d/mysqld#mysqld服务启动脚本
4.2配置文件
Linux
系统下,mysql的配置参数文件为my.cnf,一般按下面的顺序查找此文件:/etc目录、mysql安装目录、mysql数据目录。配置模板位于源
码树的support-files目录,有my-small.cnf、my-medium.cnf、my-large.cnf、my-huge.cnf四
个,关于mysql配置文件的详细信息请参阅笔者的其它文章或是mysql官方文档。
4.3启动mysqld服务
执行下面的命令启动mysql:
service mysqld start
4.3设置mysql帐号
mysql安装后默认生成两个帐号:一个是root,未设置密码,可以从本机登录到mysql;另一个是匿名帐号,无帐号名、无密码,可以从本机登录,未提供用户名的连接都将假定为此帐号。这样的设置存在着安全隐患,按下面的步骤进行更改。
以root帐号连接到mysql服务器:
mysql-u root
如果提示找不到mysql文件,请尝试使用绝对路径,如本文示例为:
/usr/local/mysql/bin/mysql-u root
命令成功执行后将进入到mysql命令提示符下:
mysql>
(以下命令均在mysql命令提示符下执行)
改变当前数据库为mysql:
use mysql
设置从本地主机登录的root帐号密码:
set password for root@localhost=password('your password');
或:
update user set password=password('your password') where user='root' and host='localhost';
删除匿名帐号:
delete from user where user='';
删除密码为空的帐号:
delete from user where password='';
删除允许非localhost主机登录的帐号:
delete from user where host<>'localhost';
执行下面的命令使更改生效:
flush privileges;
执行下面的命令退出mysql命令行:
quit
或:
/q
5.结束语
至此,Mysql基本安装完毕。希望本文能对初学者有所帮助。
如何选择适合自己的MySQL下载版本mysql下载选什么
如何选择适合自己的MySQL下载版本?
MySQL是一个用于管理关系型数据库的全球知名开源软件。其提供了多种版本供下载,包括社区版、企业版等。然而,如何选择适合自己的MySQL下载版本并不是一件易事。本文将为读者介绍如何选择适合自己的MySQL下载版本。
一、了解基本的MySQL版本分类
MySQL版本可以分为社区版与企业版,其中,社区版是免费的,企业版则需要付费。此外,MySQL还提供了多个版本形式,如源代码、二进制版本、RPM、DEB等。下面简述一下这些版本:
源代码版本:完整的MySQL源代码,对开发者较为友好,适合对MySQL底层有较深了解的技术人员。
二进制版本:适合普通开发者和管理员,提供了bin格式、zip格式等。
RPM版本:主要适用于CentOS、RedHat等Linux发行版。
DEB版本:主要适用于Ubuntu、Debian等Linux发行版。
二、确定系统平台与操作系统
MySQL支持多种操作系统,从Windows到各式各样的Linux,还包括各种UNIX系统。
不同的操作系统需要下载不同的MySQL版本,比如,要下载Windows版的MySQL,就需要到MySQL官网上下载Windows版本的MySQL。
操作系统的位数也会影响到您的选择。32位Windows操作系统只支持32位MySQL,64位Windows操作系统则支持32位和64位MySQL。要清楚你的系统是32位还是64位,通过以下方式可以查询:
在Windows中:单击“我的电脑”鼠标右键——>选择“属性”。
在Linux中:打开终端——>输入“uname-a”。
三、选择MySQL版本
通常,适合新手的MySQL版本是社区版MySQL。在MySQL官网上下载社区版的MySQL版本非常简单,只需进入,然后选择适用于自己操作系统的二进制版本或压缩版本即可。
企业版则需要用户花费大量金钱去购买。一般企业版会提供更多的特性和功能,以及更好的度量和监控支持。
对于开发人员而言,如果不需要部署高可用、分布式集群等特殊情况,社区版的MySQL就足够了。 MySQL官网上也提供了很多丰富的文档和资料以便开发人员进行学习和使用。
综上所述,选择适合自己的MySQL下载版本是一件很重要的事情。读者可以参考以上三点来进行选择,以得到最合适的版本。同时,MySQL官网上也提供了丰富的文档和教程,开发人员可以在此学习使用MySQL。