




已阅读5页,还剩7页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
几乎所有基于GNU工具的项目都使用GNU的auto系列工程管理工具管理工程。那3个命令是工程发行代码包的基本编译安装方式。 configure是根据系统环境及某些自定义工程脚步生产Makefile make就是编译工程咯,相当于make all make install就是安装工程文件到系统咯 make dist-gzip就是生成工程代码包了,XXX.tar.gz文件。 如果不是自己写工程管理倒是没必要看auto系列文档,呵呵,很大的。linux下安装MySQL的大全 例:安装mysql 4.1.21# groupadd mysql /添加用户组# useradd -g mysql mysql /添加用户# tar -zxvf mysql-4.1.21.tar.gz /解压# cd mysql-4.1.21 进入解压文件夹# ./configure -prefix=/usr/local/mysql -with-charset=gbk# make# make install# cp support-files/f /etc/f设置自启动# cp support-files/mysql.server /etc/rc.d/init.d/mysqld# chmod 700 /etc/rc.d/init.d/mysqld# chkconfig -add mysqld(关于chkconfig: 在/etc/init.d目录下,任意打开一个启动脚本,你会发现在其顶部的注释中,基本上都有以下一行: chkconfig 235 56 34(也可能是其他数字组合)就以chkconfig 235 56 34为例,235表示该启动脚本对应的服务将在系统启动级别2, 3, 5级启动。而56表示其启动优先级为56,所谓的优先级,就是在rc脚本中出现在各个符号链接名中的数字。那么34是什么相信大家已经猜到了,对了,他就是终止优先级。Linux下利用CHKCONFIG管理系统服务NAMEchkconfig -更新并询问系统服务的运行级信息。摘要(SYNOPSIS)chkconfig -list namechkconfig -add namechkconfig -del namechkconfig -level levels name chkconfig -level levels name描述(DESCRIPTION)chkconfig提供了一个命令行工具,它可以让管理员通过操纵行号标实来维护/etc/rc0-6.d目录层,以减轻管理员的工作强度。chkconfig有五个不同的功能:增加新的系统服务,删除服务,列举当前已经启动的系统服务,改变服务启动状态,及检测个别服务的启动情况。当chkconfig 不带任何参数运行的时候,它显示简略的使用说明。如果仅提供一个服务名,它将检测当前系统是否在特定运行级运行此服务。如果服务正在运行,chkconfig将显示true(是),否则显示否。使用-level运行级参数,chkconfig将询问选择一个非当前运行级以外的一个运行级运行服务。如果将on,off,或reset标实在服务名的后面,chkconfig将改变此指定服务的运行状态。如on和off标实用来提示服务的启动与停止,分别在不同的运行级进行控制。reset参数将重置指定服务。默认情况下,on和off参数只对2,3,4,5运行级发生作用,而reset参数可以对所有运行级发生作用。-level参数就是用来指定对哪个运行级进行作用的。参数(OPTION)-level levels指定服务的运行级,有levelschkconfig 命令也可以用来激活和解除服务。chkconfig -list 命令显示系统服务列表,以及这些服务在运行级别0到6中已被启动(on)还是停止(off)。chkconfig 还能用来设置某一服务在某一指定的运行级别内被启动还是被停运。譬如,要在运行级别3、4、5中停运 nfs 服务,使用下面的命令:chkconfig -level 345 nfs off)安装完以后要初始化数据库,要是升级安装的请跳过 # cd /usr/local/mysql# /usr/local/mysql/bin/mysql_install_db -user=mysql# chown -R root .# chown -R mysql var# chgrp -R mysql .# /usr/local/mysql/bin/mysqld_safe -user=mysql &好了,至此mysql安装完毕,你可以这样起动你的mysql服务# /etc/rc.d/init.d/mysqld start# ln -s /usr/local/mysql/bin/mysql /sbin/mysql# ln -s /usr/local/mysql/bin/mysqladmin /sbin/mysqladmin为了能让系统找到mysql,请运行如下命令# PATH=$PATH:/usr/local/mysql/bin# export PATH# echo /usr/local/mysql/lib/mysql /etc/ld.so.conf# ldconfig日志管理开启错误日志 (在safe_mysqld项下添加)# vi /etc/fsafe_mysqlderr-log=/var/log/mysqld/err.log开启常规日志和更新日志 (在mysqld项下添加)# vi /etc/fmysqldlog=/var/log/mysqld/log.loglog-update=/var/log/mysqld/update.log创建日志文件并设置权限# mkdir /var/log/mysqld# touch /var/log/mysqld/err.log /var/log/mysqld/log.log /var/log/mysqld/update.log# chown -R mysql.mysql /var/log/mysqld# service mysqld restart说明:错误日志包含了服务器写入标准错误输出设备的所有消息,同时还包括了mysql服务的启动和关闭事件常规日志用来记录有关mysql服务器运行的常规信息,包括用户的连接、查询及其他各种时间更新日志用来记录修改数据库的查询信息,包括所有涉及数据库修改的SQl语句的查询记录建议调试结束后关闭日志三、登录MySQL登录MySQL的命令是mysql, mysql 的使用语法如下:mysql -u username -h host -ppassword dbnameusername 与 password 分别是 MySQL 的用户名与密码,mysql的初始管理帐号是root,没有密码,注意:这个root用户不是Linux的系统用户。MySQL默认用户是root,由于初始没有密码,第一次进时只需键入mysql即可。roottest1 local# mysqlWelcome to the MySQL monitor.Commands end with ; or g.Your MySQL connection id is 1 to server version: 4.0.16-standardType help; or h for help. Type c to clear the buffer.mysql出现了“mysql”提示符,恭喜你,安装成功!增加了密码后的登录格式如下:mysql -u root -pEnter password: (输入密码)其中-u后跟的是用户名,-p要求输入密码,回车后在输入密码处输入密码。注意:这个mysql文件在/usr/bin目录下,与后面讲的启动文件/etc/init.d/mysql不是一个文件。四、MySQL的几个重要目录MySQL安装完成后不象SQL Server默认安装在一个目录,它的数据库文件、配置文件和命令文件分别在不同的目录,了解这些目录非常重要,尤其对于Linux的初学者,因为 Linux本身的目录结构就比较复杂,如果搞不清楚MySQL的安装目录那就无从谈起深入学习。下面就介绍一下这几个目录。1、数据库目录/var/lib/mysql/ 或者是 /usr/local/mysql/var2、配置文件/usr/share/mysql(mysql.server命令及配置文件)3、相关命令/usr/bin(mysqladmin mysqldump等命令)4、启动脚本/etc/rc.d/init.d/(启动脚本文件mysql的目录)五、修改登录密码MySQL默认没有密码,安装完毕增加密码的重要性是不言而喻的。1、命令usr/bin/mysqladmin -u root password new-password格式:mysqladmin -u用户名 -p旧密码 password 新密码2、例子例1:给root加个密码123456。键入以下命令 :roottest1 local# /usr/bin/mysqladmin -u root password 123456注:因为开始时root没有密码,所以-p旧密码一项就可以省略了。3、测试是否修改成功 1)不用密码登录roottest1 local# mysqlERROR 1045: Access denied for user: rootlocalhost (Using password: NO)显示错误,说明密码已经修改。2)用修改后的密码登录roottest1 local# mysql -u root -pEnter password: (输入修改后的密码123456)Welcome to the MySQL monitor.Commands end with ; or g.Your MySQL connection id is 4 to server version: 4.0.16-standardType help; or h for help. Type c to clear the buffer.mysql成功!这是通过mysqladmin命令修改口令,也可通过修改库来更改口令。六、启动与停止1、启动MySQL安装完成后启动文件mysql在/etc/init.d目录下,在需要启动时运行下面命令即可。roottest1 init.d# /etc/init.d/mysql start2、停止/usr/bin/mysqladmin -u root -p shutdown3、自动启动1)察看mysql是否在自动启动列表中roottest1 local#/sbin/chkconfig ?list2)把MySQL添加到你系统的启动服务组里面去roottest1 local#/sbin/chkconfig? addmysql3)把MySQL从启动服务组里面删除。roottest1 local#/sbin/chkconfig? delmysql七、更改MySQL目录MySQL默认的数据文件存储目录为/var/lib/mysql。假如要把目录移到/home/data下需要进行下面几步:1、home目录下建立data目录cd /homemkdir data2、把MySQL服务进程停掉:mysqladmin -u root -p shutdown3、把/var/lib/mysql整个目录移到/home/datamv /var/lib/mysql/home/data/这样就把MySQL的数据文件移动到了/home/data/mysql下4、找到f配置文件如果/etc/目录下没有f配置文件,请到/usr/share/mysql/下找到*.cnf文件,拷贝其中一个到/etc/并改名为f)中。命令如下: roottest1 mysql# cp /usr/share/mysql/f/etc/f5、编辑MySQL的配置文件/etc/f为保证MySQL能够正常工作,需要指明mysql.sock文件的产生位置。 修改socket=/var/lib/mysql/mysql.sock一行中等号右边的值为:/home/mysql/mysql.sock 。操作如下: vi f (用vi工具编辑f文件,找到下列数据修改之) # The MySQL server mysqld port= 3306#socket = /var/lib/mysql/mysql.sock(原内容,为了更稳妥用“#”注释此行) socket = /home/data/mysql/mysql.sock(加上此行)6、修改MySQL启动脚本/etc/rc.d/init.d/mysql最后,需要修改MySQL启动脚本/etc/rc.d/init.d/mysql,把其中datadir=/var/lib/mysql一行中,等号右边的路径改成你现在的实际存放路径:home/data/mysql。roottest1 etc# vi/etc/rc.d/init.d/mysql#datadir=/var/lib/mysql(注释此行)datadir=/home/data/mysql (加上此行)7、重新启动MySQL服务/etc/rc.d/init.d/mysqlstart或用reboot命令重启Linux如果工作正常移动就成功了,否则对照前面的7步再检查一下。八、MySQL的常用操作注意:MySQL中每个命令后都要以分号;结尾。1、显示数据库mysql show databases;+-+| Database |+-+| mysql| test |+-+2 rows in set (0.04 sec)Mysql刚安装完有两个数据库:mysql和test。mysql库非常重要,它里面有MySQL的系统信息,我们改密码和新增用户,实际上就是用这个库中的相关表进行操作。2、显示数据库中的表mysql use mysql; (打开库,对每个库进行操作就要打开此库,类似于foxpro )Database changedmysql show tables;+-+| Tables_in_mysql |+-+| columns_priv| db| func| host| tables_priv | user|+-+6 rows in set (0.01 sec)3、显示数据表的结构:describe 表名;4、显示表中的记录:select * from 表名;例如:显示mysql库中user表中的纪录。所有能对MySQL用户操作的用户都在此表中。Select * from user;5、建库:create database 库名;例如:创建一个名字位aaa的库mysql create databases aaa;6、建表:use 库名;create table 表名 (字段设定列表);例如:在刚创建的aaa库中建立表name,表中有id(序号,自动增长),xm(姓名),xb(性别),csny(出身年月)四个字段use aaa;mysql create table name (id int(3) auto_increment not null primary key, xm char(8),xb char(2),csny date);可以用describe命令察看刚建立的表结构。mysql describe name;+-+-+-+-+-+-+| Field | Type| Null | Key | Default | Extra|+-+-+-+-+-+-+| id| int(3)| PRI | NULL| auto_increment | xm| char(8) | YES| | NULL| xb| char(2) | YES| | NULL| csny| date| YES| | NULL|+-+-+-+-+-+-+7、增加记录例如:增加几条相关纪录。mysql insert into name values(,张三,男,1971-10-01);mysql insert into name values(,白云,女,1972-05-20);可用select命令来验证结果。mysql select * from name;+-+-+-+-+| id | xm | xb | csny |+-+-+-+-+|1 | 张三 | 男 | 1971-10-01 |2 | 白云 | 女 | 1972-05-20 |+-+-+-+-+8、修改纪录例如:将张三的出生年月改为1971-01-10mysql update name set csny=1971-01-10 where xm=张三;9、删除纪录例如:删除张三的纪录。mysql delete from name where xm=张三;10、删库和删表drop database 库名;drop table 表名;九、增加MySQL用户格式:grant select on 数据库.* to 用户名登录主机 identified by 密码例1、增加一个用户user_1密码为123,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MySQL,然后键入以下命令:mysql grant select,insert,update,delete on *.* to user_1% Identified by 123;例1增加的用户是十分危险的,如果知道了user_1的密码,那么他就可以在网上的任何一台电脑上登录你的MySQL数据库并对你的数据为所欲为了,解决办法见例2。例2、增加一个用户user_2密码为123,让此用户只可以在localhost上登录,并可以对数据库aaa进行查询、插入、修改、删除的操作(localhost指本地主机,即MySQL数据库所在的那台主机),这样用户即使用知道user_2的密码,他也无法从网上直接访问数据库,只能通过 MYSQL主机来操作aaa库。mysqlgrant select,insert,update,delete on aaa.* to user_2localhost identified by 123;用新增的用户如果登录不了MySQL,在登录时用如下命令:mysql -u user_1 -p-h 0(-h后跟的是要登录主机的ip地址)十、备份与恢复1、备份例如:将上例创建的aaa库备份到文件back_aaa中roottest1 root# cd/home/data/mysql(进入到库目录,本例库已由val/lib/mysql转到/home/data/mysql,见上述第七部分内容)roottest1 mysql# mysqldump -u root -p -opt aaa back_aaa2、恢复roottest mysql# mysql -u root -p ccc cd mysql ./configure-prefix=/usr/local/mysql -指定你要安装的目录make -编译make install mysql-3.*.*-pc-linux.tar.gz 我从 下的(具体版本记不清了) 用tar -vzxf 解开后,发现只有configure等,没有常见的makefile,install ./configure后 #make /没有“target” #make INSTALL 先我自己写了一个安装步骤,不过是比较老的版本,不知道对你有没有帮助: 下列安装步骤经过测试,可行! 首先将3个安装文件拷贝同一个目录,例如/usr/src目录下 Install mysql shell groupadd mysql shell useradd -g mysql mysql shell tar -zxvf mysql-3.23.45.tar.gz shell cd mysql-version shell ./configure -with-charset=big5 -prefix=/usr/local/mysql -localstatedir=/usr/local/mysql/data -with-debug -with-unix-socket-path=/tmp/mysql.sock shell make shell make install shell scripts/mysql_install_db shell chown -R root /usr/local/mysql shell chown -R mysql /usr/local/mysql/data shell chgrp -R mysql /usr/local/mysql shell cp support-files/f /etc/f shell /usr/local/mysql/bin/safe_mysqld -user=mysql & shell cd /usr/local/bin shell ln -fs /usr/local/mysql/bin/mysql mysql shell ln -fs /usr/local/mysql/share/mysql/mysql.server mysql.server 将这两个命令映射到/usr/local/bin目录下,这样可以在任何地方使用它们mysql-4.0.15.tar.gz安装:(default) -prefix=/usr/local-tar xvzf mysql-4.0.15.tar.gz-cd mysql-4.0.15-./configure -prefix=/usr/local/mysql-make-make install#以上为源代码
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论