==================================
1 文件管理2 软件管理3 系统管理
4 服务管理5 网络管理6 磁盘管理
7 用户管理8 脚本相关9 服务配置
==================================
----------------------------------
1 文件管理
----------------------------------
创建空白文件
touch
不提示删除非空目录
rm -rf目录名
(-r:递归删除 -f 强制)
##################################
恢复 rm 删除的文件(ext3)
查看磁盘分区格式
df -T
卸载挂载
umount /data/
ext3grep /dev/sdb1 --ls --inode 2
记录信息继续查找目录下文件 inode信息
ext3grep /dev/sdb1 --ls --inode 131081 # 此处是 inode
记录下 inode信息开始恢复目录
ext3grep /dev/sdb1 --restore-inode 49153
##################################
windows 文本转 linux 文本
dos2unix
linux 文本转 windows 文本
unix2dos
转换编码
iconv -f gbk -tutf8 原.txt > 新.txt
查看 md5 值
md5sum
硬链接
ln
符号连接
ln -s
查看上下翻页且显示行号
cat ? | nl |less
q 退出
结束状态
ctrl+z
查看文件开头内容
head
查看文件结尾内容
tail -f # 监视日志文件
检查文件类型
file
重命名
rename
rename source_pattern target_pattern source_files
更改默认权限
umask
按数字排序
sort -n
按数字倒叙
sort -nr
过滤重复行
sort -u
删除重复的行
uniq
重复的行出现次数
uniq -c
只显示不重复行
uniq -u
将两个文件合并用 tab键分隔开
paste a b
将两个文件合并指定'+'符号隔开
paste -d'+' a b
将多行数据合并到一行用 tab 键隔开
paste -s a
设置隐藏属性
chattr [+-=] [ASacdistu] 文件或目录
向下分面器
more
搜索
locate 字符串
查看行数
wc -l
实时某个目录下查看最新改动过的文件
watch -d-n 1 'df; ls -FlAt /path'
快速备份一个文件
cp filename{,.bak}
##################################
配置编辑器
gconf-editor
vi 配置文件
vi /etc/vimrc
编辑文件
vim
打开行号
:set nu
取消行号
:set nonu
跳转到 200
200G
取消高亮
:nohl
设置自动缩进
:set autoindent
查看文本格式
set ff
改为 unix 格式
set binary
向前翻页
ctrl+ U
向后翻页
ctrl+ D
全部替换
g/字符 1/s//字符 2/g
%s/字符 1/字符 2/g
# 普通用户打开文档不能保存
# tee 是一个把 stdin 保存到文件的小工具,而%,是 vim 当中一个只读寄存器的名字,总保存着当
前编辑文件的文件路径
:w !sudotee %
##################################
按文件名查找
find /etc -name http
查找某一类型文件
find . -type f
按照文件权限查找
find / -perm
按照文件属主查找
find / -user
按照文件所属的组来查找文件
find / -group
文件使用时间在 N 天以内
find / -atime -n
文件使用时间在 N 天以前
find / -atime +n
文件内容改变时间在 N 天以内
find / -mtime -n
文件内容改变时间在 N 天以前
find / -mtime +n
文件状态改变时间在 N 天前
find / -ctime +n
文件状态改变时间在 N 天内
find / -ctime -n
# linux 文件无创建时间
# Access 使用时间
# Modify 内容修改时间
# Change 状态改变时间(权限、属主)
查找文件长度大于 1M 字节的文件
find / -size +1000000c -print
按名字查找文件传递给-exec 后命令
find /etc -name "passwd*" -exec grep "hashlinux" {}\;
查找文件名,不取路径
find . -name 't*' -exec basename {} \;
##################################
====================================================================
----------------------------------
2 软件管理
----------------------------------
解包 tar
tar xvf 1.tar -C 目录
打包 tar
tar -cvf 1.tar *
查看 tar
tar tvf 1.tar
给 tar 追加文件
tar -rvf 1.tar 文件名
解包 gz
tar zxvpf gz.tar.gz
打包 gz
tar zcvpf gz.tar.gz
查看 gz
tar ztvpf gz.tar.gz
解压 bzip2
bzip2 -dv 1.tar.bz2
解压 gzip 到 tar
gzip -dv 1.tar.gz
压缩 tar 到 gz
gzip -v 1.tar
bzip2 压缩
bzip2 -v 1.tar
查看 bzip2
bzcat
rpm 安装
rpm -ivh
卸载
rpm -e lynx
强制卸载
rpm -e lynx --nodeps
测试
rpm --test lynx
查看所有安装的 rpm 包
rpm -qa
查找包是否安装
rpm -qa | grep http
解压 zip
unzip zip.zip
压缩 zip
zip zip.zip *
rar3.6 下载地址
http://www.rarsoft.com/rar/rarlinux-3.6.0.tar.gz
压缩文件为 rar 包
rar a rar.rar *.jpg
解压 rar 包
unrar x rar.rar
7z 压缩
7z a 7z.7z *
7z 解压
7z e 7z.7z
查看字符行
zgrep 字符 1.gz
打包/home, /etc ,但排除 /home/dmtsai
tar --exclude /home/dmtsai -zcvf myfile.tar.gz /home} # 去掉第一条 / 及其左边的字串:dir1/dir2/dir3/my.file.txt
${file##*/} # 去掉最后一条/ 及其左边的字串:my.file.txt
${file#*.} # 去掉第一个 . 及其左边的字串:file.txt
${file##*.} # 去掉最后一个 . 及其左边的字串:txt
${file%/p}"
删除含关键的一行
sed -i "/^$f/d" a
直接对文本替换
sed -i "s/=/:/" c
找到 pearls 开头在行尾加 jcui
sed -i "/^pearls/s/$/jcui/" ab.txt
标签(保存\(mar\)作为标签 1)
sed -n 's/\(mar\)got/\1ianne/p' 文件
echo "margot"|sed -n 's/\(mar\).*\(t\)/\1\2/p'
sed -e 's/^\([a-zA-Z]\+\) \([a-zA-Z]\+\)\(.*\)/\2 \1\3/g' file
在以[0-9][0-9]结尾的行后加 5
sed 's/[0-9][0-9]$/&5' 文件
打印从第 5 行到以 no 开头行之间的所有行
sed -n '5,/^no/p' 文件
修改 west 和 east 之间的所有行,在结尾处加*VACA*
sed '/west/,/east/s/$' 文件
多重编辑(先删除 1-3 行,在将 1 替换成 2)
sed -e '1,3d' -e's/1/2/' 文件
找到含 suan 的行,在后面加上读入的文件内容
sed '/suan/r 读入文件' 文件
找到含 no 的行,写入到指定文件中
sed -n '/no/w 写入文件' 文件
取出第一组数字,并且忽略掉开头的 0
sed 's/[^1-9]*\([0-9]\+\).*/\1/'
打印 1 和 3 之间的行
sed '/1/,/3/p' file
取出指定行
sed -n '1p' 文件
在第 5 行之前插入行
sed '5i\aaa'file
在第 5 行之后抽入行
sed '5a\aaa' file
在匹配行前插入一行
echo a|sed -e '/a/i\b'
在匹配行后插入一行
echo a|sed -e '/a/a\b'
echo a|sed 's/a/&\nb/g'
引用外部变量
sed -n ''$a',10p'
sed -n ""$a",10p"
取用户家目录(匹配不为/的字符和匹配:到结尾的字符全部删除)
sed -n '{s/^[^\/]*//;s/\:.*//;p}' /etc/passwd
将换行符转换为换行
echo abcd\\nabcde |sed 's/\\n/@/g' |tr '@' '\n'
删除掉@后面所有字符,和空行
sed -e 's/@.*//g' -e '/^$/d'
将几行合并成一行
echo $(cat file)|sed 's/ //g'
取一列最大值
cat tmp|awk '{print $1}'|sort -n|sed -n '$p'
查找属主权限为 7的文件
ls -l|sed -n '/^.rwx.*/p'
在 a 前面加#号
echo a|sed -e 's/a/#&/g'
##################################
图形 dialog
多选界面[方括号]
dialog --title "Check me" --checklist "Pick Numbers" 15 25 3 1 "one" "off" 2 "two""on" 3 "three"
"off" 2>tmp
多选界面(圆括号)
dialog --title "title" --radiolist "checklist" 20 60 14 tag1 "item1"on tag2 "item2"off 2>tmp
单选界面
dialog --title "title" --menu "MENU" 20 60 14 tag1 "item1" tag2 "item2" 2>tmp
进度条
dialog --title "Installation" --backtitle"Star Linux" --gauge "Linux Kernel" 10 60 50
选择 yes/no
dialog --title "标题"--backtitle "Dialog" --yesno "说明" 2060
公告
dialog --title "公告标题"--backtitle "Dialog" --msgbox "内容" 20 60
显示讯息后立即离开
dialog --title "hey" --backtitle "Dialog" --infobox "Is everything okay?"10 60
输入对话框
dialog --title "hey" --backtitle "Dialog" --inputbox "Is okay?" 10 60 "yes"
显示文档内容
dialog --title "Array 30" --backtitle "All " --textbox /root/txt 20 75
多条输入对话框
dialog --title "Add a user" --form "Add a user" 12 40 4 "Username:" 1 1 "" 1 15 15 0 "Full
name:" 2 1 "" 2 15 15 0 2>tmp
星号显示输入--insecure
dialog --title "Password" --insecure --passwordbox "请输入密码" 10 35
选择日期
dialog --stdout --title "日历" --calendar "请选择" 0 0 9 1 2010
##################################
脚本头 # sh 为当前系统默认 shell,可指定为 bash 等
#!/bin/sh
临时文件定义
errtmp=/tmp/$$`date +%s%N`.errtmp
outtmp=/tmp/$$`date +%s%N`.outtmp
true > $outtmp
随机数
$RANDOM
进程号
$$
纳秒
date +%N
在当前 bash 环境下读取并执行 FileName 中的命令
sourcefile-name # 等同 . FileName
间隔睡眠 5 秒
sleep 5
在接收到信号后将要采取的行动
trap
当前目录
$PWD
之前一个目录的路径
$OLDPWD
返回上一个目录路径
cd -
重复打印
yes
自动回答 y 或者其他
yes |rm-i*
查看目录所有文件夹
ls -p/home
查看匹配完整路径
ls -d/home/
命令替换 xargs
#将前面的内容,作为后面命令的参数
find / -perm +7000 | xargs ls -l
不换行执行下一句话
echo -n aa;echo bb
使转义生效
echo -e "s\tss\n\n\n"
取字符串中字元
echo $a | cut -c2-6
排列组合(括号内一个元素分别和其他括号内元素组合)
echo {a,b,c}{a,b,c}{a,b,c}
返回目录名
pwd | awk -F/ '{ print "目录名:",$2 }'
替换上一条命令中的(foo)一个短语(bar)
^foo^bar^
!!:s/foo/bar/
!!:gs/foo/bar
##################################
shell 例子
判断参数是否为空-空退出并打印 null
#!/bin/sh
echo $1
name=${1:?"null"}
echo $name
##################################
循环数组
for ((i=0;i<${#o[*]};i++))
do
echo ${o[$i]}
done
##################################
判断路径
if[ -d /root/Desktop/text/123 ];then
echo "找到了 123"
if[ -d /root/Desktop/text ]
then echo "找到了 text"
else echo "没找到 text"
fi
else echo "没找到 123 文件夹"
fi
##################################
匹配替换密码
#!/bin/sh
cat mailpassword > temp.txt
sed -i "s/:/ =/" temp.txt
w=`awk -F " = " '{print $1}' temp.txt`
for d in $w
do
grep -w $d svnpassword>/dev/null
if[ $? -eq 0 ]
then
sed -i "/^$d/d" svnpassword
grep "^$d" temp.txt >> svnpassword
#替换到转义就出问题
#sed -i "/^$d/c $(grep "^$d" temp.txt)" svnpassword
fi
done
rm temp.txt
##################################
多行合并
将两行并为一行(去掉换行符)
sed '{N;s/\n//}' file
将 4行合并为一行(可扩展)
awk '{if(NR%4==0){print $0} else {printf"%s ",$0}}' file
将所有行合并
awk '{printf"%s ",$0}'
##################################
shift 用法
./cs.sh 1 2 3
#!/bin/sh
until [ $# -eq 0 ]
do
echo "第一个参数为: $1参数个数为: $#"
#shift 命令执行前变量 $1 的值在 shift 命令执行后不可用
shift
done
##################################
给脚本加参数 getopts
#!/bin/sh
while getopts :ab: name
do
case $name in
a) aflag=1
;;
b) bflag=1
bval=$OPTARG
;;
\?) echo "USAGE:`basename $0` [-a] [-b value]"
exit 1
;;
esac
done
if[ ! -z $aflag ] ; then
echo "option -a specified"
echo "$aflag"
echo "$OPTIND"
fi
if[ ! -z $bflag ] ; then
echo "option -b specified"
echo "$bflag"
echo "$bval"
echo "$OPTIND"
fi
echo "here $OPTIND"
shift $(($OPTIND -1))
echo "$OPTIND"
echo " `shift $(($OPTIND -1))` "
##################################
判断脚本参数是否正确
./test.sh -p123 -P 3306 -h 127.0.0.1 -u root
#!/bin/sh
if[ $# -ne 8 ];then
echo "USAGE: $0 -u user -p passwd -P port -h host"
exit 1
fi
while getopts :u:p:P:h: name
do
case $name in
u)
mysql_user=$OPTARG
;;
p)
mysql_passwd=$OPTARG
;;
P)
mysql_port=$OPTARG
;;
h)
mysql_host=$OPTARG
;;
*)
echo "USAGE: $0 -u user -p passwd -P port -h host"
exit 1
;;
esac
done
if[ -z $mysql_user ] || [ -z $mysql_passwd ] || [ -z $mysql_port ] || [ -z $mysql_host ]
then
echo "USAGE: $0 -u user -p passwd -P port -h host"
exit 1
fi
echo $mysql_user $mysql_passwd $mysql_port $mysql_host
#结果 root123 3306127.0.0.1
##################################
dialog 取值接值退出
outtmp=/tmp/outtmp
dialog --no-shadow --backtitle "hashlinux制作" --title "请选择" --ok-label "提交" --cancel-label "取消"
--menu "请选择" 10 60 0 \
1 "[目录]" \
q "[退出]" \
2> $outtmp
#判断提交取消
if[ $? == "1" ]
then
break
#continue
fi
#只判断退出
pt=`awk '{print}' $outtmp`
if[ $pt == q ]
then
break
fi
#判断操作
case $pt in
1)
#操作
;;
q)
exit #break
;;
esac
##################################
dialog 输入对话框加判断
while :
do
outtmp=/tmp/outtmp
dialog --title "hashlinux制作" --form "请输入" 20 60 10 "用户:" 1 2 "" 1 15 35 0 "ID:" 2 2 "" 2
15 35 0 "" 6 2 ""6 0 0 0 "输入格式如下" 7 2 "" 7 0 0 0 "说明" 8 2 "" 8 0 0
0 2> $outtmp
yh=`sed -n '1p' $outtmp`
id=`sed -n '2p' $outtmp`
ifecho $yh | grep -e '^[1-9][0-9]\{0,2\}' > /dev/null 2>&1
then
if echo $id | grep -e '^[1-9][0-9]\{0,12\}' > /dev/null 2>&1
then
break
else
echo "您输入的不合法,请从新输入!"
fi
else
echo "您输入的不合法,请从新输入!"
fi
done
##################################
打印表格
#!/bin/sh
clear
awk 'BEGIN{
print "+--------------------+--------------------+";
printf "|%-20s|%-20s|\n","Name","Number";
print "+--------------------+--------------------+";
}'
a=`grep "^[A-Z]" a.txt |sort +1 -n |awk '{print $1":"$2}'`
#cat a.txt |sort +1 -n |while read list
for list in $a
do
name=`echo $list |awk -F: '{print $1}'`
number=`echo $list |awk -F: '{print $2}'`
awk 'BEGIN{printf "|%-20s|%-20s|\n","'"$name"'","'"$number"'";
print "+--------------------+--------------------+";
}'
done
awk 'BEGIN{
print " *** The End *** "
print " "
}'
##################################
判断日期是否合法
#!/bin/sh
while read a
do
if echo$a | grep -q "-" && date -d $a +%Y%m%d > /dev/null 2>&1
then
if echo $a | grep -e '^[0-9]\{4\}-[01][0-9]-[0-3][0-9]$'
then
break
else
echo "您输入的日期不合法,请从新输入!"
fi
else
echo "您输入的日期不合法,请从新输入!"
fi
done
echo "日期为$a"
##################################
打印日期段所有日期
#!/bin/bash
qsrq=20010101
jsrq=20010227
n=0
>tmp
while :;do
current=$(date +%Y%m%d -d"$n day $qsrq")
if[[ $current == $jsrq ]];then
echo $current >>tmp;break
else
echo $current >>tmp
((n++))
fi
done
rq=`awk 'NR==1{print}' tmp`
##################################
打印提示
cat < #内容 EOF 登陆远程执行命令(特殊符号需要\转义) ssh root@ip << EOF #执行命令 EOF 登陆 mysql 执行命令 mysql -uroot -ppasswd -S mysql.sock --default-character-set=gbk -A< #mysql 命令 EOF ################################## 数学计算的小算法 #!/bin/sh A=1 B=1 while [ $A-le 10 ] do SUM=`expr $A\* $B` echo "$SUM" if[ $A= 10 ] then B=`expr $B + 1` A=1 fi A=`expr $A+ 1` done ################################## 竖行转横行(三种) cat file|tr '\n' ' ' echo $(cat file) #!/bin/sh for i in `cat file` do a=${a}""${i} done echo $a ################################## 取用户的根目录 #! /bin/bash #showhome.sh IFS=: while read namepass uid gid gecos home shell do echo $home done 执行./showhome.sh < /etc/passwd ################################## 把汉字转成 encode 格式: echo 论坛 | tr -d "\n" | xxd -i | sed -e "s/0x/%/g" | tr-d " ,\n" 大写的: echo 论坛 | tr -d "\n" | xxd -i | sed -e "s/0x/%/g" | tr-d " ,\n" | tr "[a-f]" "[A-F]" ################################## 把带有大写字母的文件名改为全部小写 #!/bin/bash for fin *;do mv $f `echo $f |tr "[A-Z]" "[a-z]"` done ################################## 查找连续多行,在不连续的行前插入 #/bin/bash lastrow=null i=0 cat incl|while read line do i=`expr $i + 1` ifecho "$lastrow" | grep "#include <[A-Z].h>" then if echo "$line" | grep -v "#include<[A-Z].h>" then sed -i ''$i'i\\/\/Allheader files are include' incl i=`expr $i + 1` fi fi lastrow="$line" done ################################## ==================================================================== ---------------------------------- 9 服务配置 ---------------------------------- samba 修改配置文 /etc/samba/smb.conf [global] workgroup =WORKGROUP server string = sambaserver security=share hosts allow=网络主机 [file] comment=home directories path=/etc/samba/hashlinux public=yes writable=yes browseable=yes 重启 service smb restart linux 访问 windows 共享 smbclient -L //ip 地址或计算机名 ################################## DNS 服务器 DNS 主配置文件,moon.com 域名,zone.moon.com 域的配置文件 vi /etc/named.conf zone "moon.com" IN { type master; file "zone.moon.com"; allow-update { none; }; }; 测试主配置文件 named-checkconf 新建域的配置文件 zone.moon.com vi /var/named/chroot/var/named/zone.moon.com $TTL 86400 @ IN SOA xs. quanzhou722.163.com. ( 20102014 3H 15M 1W 1D ) IN NS xs. IN MX 5 mail. www IN A 192.168.1.209 ftp IN A 192.168.1.209 mail IN A 192.168.1.209 测试 moon.com 域配置文件 named-checkzone moon.com /var/named/chroot/var/named/zone.moon.com 建立域配置文件的软连接 ln -s/var/named/chroot/var/named/zone.moon.com /var/named/zone.moon.com 重启 named 服务 service named restart 设置 DNS vi /etc/resolv.conf 测试解析是否成功 host www.moon.com nslookup www.moon.com ################################## ftp 配置 查看 vsftp 是否安装 rpm -qa | grep vsftp 主配置文件 vi /etc/vsftpd/vsftpd.conf 启动 VSFTPD 服务 service vsftpd restart 查看 21 端口是否开放 netstat-atln |grep 21 1、匿名用户是否允许访问 anonymous_enable=YES anon_mkdir_write_enable=YES 2、本地用户管理 local_enable=YES chroot_list_enable=YES chroot_list_file=/etc/vsftpd.chroot_list 将用户添加到 vsftpd.chroot_list 文件中允许访问 cat /etc/passwd |grep ":5[0-9][0-9]:" | awk -F : '{print $1}' > /etc/vsftpd.chroot_list 3、虚拟用户管理 (1)要用到文件数据库 db4 rpm -qa |grep db4 (2)将帐户放入文本:(奇数行)用户名 (偶数行)密码 vi zhanghu.dat (3)生成帐户的文件数据库 db_load -T -t hash -fzhanghu.dat /etc/vsftpd/vsftpd_zhanghu.db (4)修改文件数据库访问权限 chmod 600 /etc/vsftpd/vsftpd_zhanghu.db (5)手工建立虚拟用户所需的 PAM 配置文件 vi /etc/pam.d/vsftpd.zhanghu auth required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_zhanghu account required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_zhanghu (6)添加一个虚拟用户的入口帐户 useradd -d /var/ZhanDian -s /sbin/nologin XuNiRuKou (7)在主配置文件中添加虚拟用户的配置内容 虚拟用户的新添加配置 chroot_local_user=YES guest_enable=YES guest_username=XuNiRuKou pam_service_name=vsftpd.zhanghu (8)在 vsftpd.conf 配置文件中指定用户配置文件的目录 user_config_dir=/etc/vsftpd/vsftpd_zhandian (9)建立配置文件中指定用户配置文件的目录 mkdir /etc/vsftpd/vsftpd_zhandian (10)因为入口帐户是一个本地帐户,所以要指定虚拟用户具有本地帐户的权限,才能读写 自 己空间中的文件 虚拟用户就可以就拥有写权限 virtual_use_local_privs=YES (11) touch /etc/vsftpd/vsftpd_zhandian/hashlinux echo "local_root=/var/ZhanDian/hashlinux" >> /etc/vsftpd/vsftpd_zhandian/hashlinux (12) mkdir /var/ZhanDian/hashlinux (13) chown -R XuNiRuKou:XuNiRuKou /var/ZhanDian/ (14)重启服务 /etc/init.d/vsftpd restart (15)客户端虚拟账号测试 建立用户脚本。最好在加上判断用户名是否存在 #!/bin/sh echo 请输入用户名 read y echo $y >> zhanghu.dat echo 请输入密码 read m echo $m >> zhanghu.dat db_load -T -t hash -fzhanghu.dat /etc/vsftpd/vsftpd_zhanghu.db chmod 600 /etc/vsftpd/vsftpd_zhanghu.db touch /etc/vsftpd/vsftpd_zhandian/$y echo "local_root=/var/ZhanDian/$y" >> /etc/vsftpd/vsftpd_zhandian/$y mkdir /var/ZhanDian/$y chown -R XuNiRuKou:XuNiRuKou /var/ZhanDian/$y /etc/init.d/vsftpd restart ################################## httpd 安装 tar zxvf httpd-2.2.12.tar.gz cd httpd-2.2.12 ./configure --prefix=/usr/local/httpd \ --enable-rewrite make && make install ls /usr/local/ groupadd www useradd -g www-M -s /sbin/nologin www cd /usr/local/httpd/ vi conf/httpd.conf 服务器开启在软件安装目录的 bin 中 ./apachectl start 网页放在的 htdocs 中 开机启动 vi /etc/rc.d/rc.local /usr/local/httpd/bin/apachectl start 如果启动提示 httpd: Could not reliably determine the server fully qualified domain name, using 127.0.0.1 for ServerName 修改/etc/hosts 计算机名 在 httpd.conf 中开启 ServerName 127.0.0.1:80 编码设置 AddDefaultCharset UTF-8 AddDefaultCharset GB2312 ################################## mysql 源码安装 groupadd mysql useradd mysql -g mysql -M -s /bin/false tar zxvf mysql-5.0.22.tar.gz cd mysql-5.0.22 ./configure --prefix=/usr/local/mysql \ --with-client-ldflags=-all-static \ --with-mysqld-ldflags=-all-static \ --with-mysqld-user=mysql \ --with-extra-charsets=all \ --with-unix-socket-path=/var/tmp/mysql.sock make && make install 生成 mysql 用户数据库和表文件,在安装包中输入。 scripts/mysql_install_db --user=mysql vi ~/.bashrc export PATH="$PATH: /usr/local/mysql/bin" 配置文件,有 large,medium,small 三个,根据机器性能选择 cp support-files/my-medium.cnf /etc/my.cnf cp support-files/mysql.server /etc/init.d/mysqld chmod 700 /etc/init.d/mysqld cd /usr/local chmod 750 mysql -R chgrp mysql mysql -R chown mysql mysql/var -R cp /usr/local/mysql/libexec/mysqld mysqld.old ln -s/usr/local/mysql/bin/mysql /sbin/mysql ln -s/usr/local/mysql/bin/mysqladmin /sbin/mysqladmin ln -s-f /usr/local/mysql/bin/mysqld_safe /etc/rc.d/rc3.d/S15mysql5 ln -s-f /usr/local/mysql/bin/mysqld_safe /etc/rc.d/rc0.d/K15mysql5 ################################## mysql rpm 安装 到 http://www.mysql.com/downloads/mysql 下载 mysql RPM(service 和 client) , MySQL-server-community-5.1.51-1.rhel5.i386.rpm 安装服务端 MySQL-client-community-5.1.51-1.rhel5.i386.rpm 安装客户端 MySQL-devel-community-5.1.51-1.rhel5.i386.rpm 用于 php 的 mysql 安装 rpm –ivh MySQL-server-community-5.1.51-1.rhel5.i386.rpm rpm –ivh MySQL-client-community-5.1.51-1.rhel5.i386.rpm rpm –ivh MySQL-devel-community-5.1.51-1.rhel5.i386.rpm /etc/init.d/mysqld start mysqladmin -u root password 'hashlinux' mysql -u root -S /var/lib/mysql/mysql.sock -p 数据目录/var/lib/mysql chkconfig --list |grep mysqld chkconfig --level 3 mysqld on 配置文件(日志\pid) /etc/my.cnf ll /usr/bin/mysql* ################################## mysql 常用命令 启动 mysql 服务 ./mysql/bin/mysqld_safe --user=mysql & 登录 mysql 的命令 格式: mysql -h 主机地址 -u 用户名-p 用户密码 mysql -h110.110.110.110 -P3306 -uroot -p mysql -uroot -p -S /data1/mysql5/data/mysql.sock -A --default-character-set=GBK 刷新 flush privileges; 显示所有数据库 show databases; 打开数据库 use dbname; 显示选中数据库中所有的表 show tables; 查看表结构 desc tables; 删除数据库 drop database name; 删除表 drop table name; 创建数据库 create database name; mysqladmin -h myhost -u root -p create dbname 创建表 create table ka(ka_idvarchar(6),qianshu int); 插入字段 alter table name add column accountid(列名) int(11) NOT NULL(字段不为空); 不登陆 mysql 插入字段 mysql -uroot -p -S mysql.sock -e "use db;alter table gift add column accountid int(11) NOT NULL;flush privileges;" 查询 select 列名称 from 表名称; select host,user,password from user; 备份数据库 mysqldump -h host -u root -pdbname >dbname_backup.sql mysqlhotcopy 只能备份 MyISAM 引擎 /bin/mysqlhotcopy -u root -p 还原数据库 mysql -h host -u root -pdbname < dbname_backup.sql 登陆 mysql 后还原 sql 文件 source 路径.sql 赋予查询权限(没有用户,直接创建) grant select on db.* to log@"%" Identified by "123456"; 赋予所有权限(没有用户,直接创建) grant all privileges on db.* to log@"IP" identified by '123456' withgrant option; 更改密码 update user set password=password('新密码') where user='root' mysqladmin -u root password 'hashlinux' mysql 查看所有用户的语句 select user(); 删除用户 delete from user where user='sss' andhost='localhost' ; 查看主从 show slave status\G; 查看主从复制进程 show processlist; 添加索引 解决停 mysql 速度慢 ALTER TABLE playerADD INDEX weekcredit_faction_index (weekcredit, faction); 创建主从复制用户 grant replication slave on *.* to '用户'@'%' identifiedby '密码'; 备份表 mysqldump -u root -p -S mysql.sock --default-character-set=utf8 --hex-blob db table1 table1 > /data/db.sql 查看系统的字符集和排序方式的设定 SHOW VARIABLES LIKE 'character_set_%'; 查看 mysql 所有参数 show variables; 删除空用户 delete from user where user=''; 创建表指定存储引擎的类型: CREATE TABLE innodb (id int, titlechar(20)) ENGINE = INNODB CREATE TABLE myisam (id int, title char(20)) ENGINE =MyISAM 改变现有的表使用的存储引擎: ALTER TABLE mytable ENGINE = MyISAM 查询表引擎 SHOW TABLE STATUS from 数据库库名 where Name='表名'; SHOW TABLE STATUS from db where Name='innodb'; 查看 mysql 变量 SHOW VARIABLES; 查询用户权限 select host,user,password from user; 查看表的引擎状态 show table status ################################## gd 安装 分别安装组件 libxml、zlib、freetype、libpng、jpegsrc、gd libxml2-2.6.24.tar.bz2 zlib-1.2.3.tar.gz freetype-2.2.1.tar.gz libpng-1.2.10.tar.gz jpegsrc.v6b.tar.gz gd-2.0.33.tar.gz libxml安装 tar xzvf libxml2-2.6.24.tar.bz2 tar xvf libxml2-2.6.24.tar cd libxml2-2.6.24 ./configure make make install zlib 安装 tar xzvf zlib-1.2.3.tar.gz cd zlib-1.2.3 ./configure make make install freetype 安装 tar xzvf freetype-2.2.1.tar.gz cd freetype-2.2.1 ./configure --prefix=/usr/local/php/modules/freetype make make install libpng 安装 tar xzvf libpng-1.2.10.tar.gz cd libpng-1.2.10 ./configure --prefix=/usr/local/php/modules/libpng jpeg 安装 mkdir /usr/local/php/modules/jpeg6 mkdir /usr/local/php/modules/jpeg6/bin mkdir /usr/local/php/modules/jpeg6/lib mkdir /usr/local/php/modules/jpeg6/include mkdir /usr/local/php/modules/jpeg6/man mkdir /usr/local/php/modules/jpeg6/man/man1 一句创建 mkdir -pv /usr/local/jpeg/{,bin,lib,include,man/man1,man1} tar zxvf jpegsrc.v6b.tar.gz cd jpeg-6b/ ./configure --prefix=/usr/local/php/modules/jpeg6 \ --enable-shared \ --enable-static make make install gd 安装 tar zxvf gd-2.0.33.tar.gz cd gd-2.0.33 ./configure --prefix=/usr/local/gd2 \ --with-jpeg=/usr/local/php/modules/jpeg6 \ --with-png=/usr/local/php/modules/libpng \ --with-zlib \ --with-freetype=/usr/local/php/modules/freetype 修改 Makefile 文件 231 行,重复的第二个 freetype 改为 libpng make make install php 安装 tar xvf php-5.1.6.tar cd php-5.1.bz2.6 ./configure --prefix=/usr/local/php \ --sysconfdir=/etc \ --with-apxs2=/usr/local/httpd/bin/apxs \ --with-config-file-path=/usr/local/php/lib \ --with-libxml-dir=/usr/local/libxml2 \ --with-zlib \ --with-jpeg-dir=/usr/local/php/modules/jpeg6 \ --with-freetype-dir=/usr/local/php/modules/freetype \ --with-gd=/usr/local/gd2 \ --with-openssl \ --with-regex=php \ --with-gnu-ld \ --with-tsrm-pthreads \ --with-bz2 \ --with-gettext \ --with-db4=/usr \ --enable-ftp \ --enable-bcmath \ --enable-dba \ --enable-sockets \ --enable-soap \ --enable-zend-multibyte \ --enable-mbstring \ --with-curlwrappers \ --with-curl=/usr/local/curl \ --with-pdo-mysql=/usr/local/mysql \ --with-mysql=/usr/local/mysql \ --with-mysqli=/usr/local/mysql/bin/mysql_config make make install cp php.ini-recommended /usr/local/php/lib/php.ini vi /usr/local/php/lib/php.ini 在 PHP.IN 添加 [eaccelerator] extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/eaccelerator.so eaccelerator.shm_size="32" eaccelerator.cache_dir="/usr/local/cache/eaccelerator" eaccelerator.enable="1" eaccelerator.optimizer="1" eaccelerator.check_mtime="1" eaccelerator.debug="0" eaccelerator.filter="" eaccelerator.shm_max="0" eaccelerator.shm_ttl="0" eaccelerator.shm_prune_period="0" eaccelerator.shm_only="0" eaccelerator.compress="1" eaccelerator.compress_level="9" 完成后在/usr/local/httpd/conf/httpd.conf 文件上添加如下一行: AddType application/x-httpd-php .php .php5 ln -s/usr/local/php/bin/php /sbin/php vi index.php