存档

文章标签 ‘linux’

在linux下用Apache建虚拟主机(一个IP多个域名)

2010年11月27日 没有评论
如有两个域名,分别是hello.abc.com和play.abc.com,需把这两个域名都绑定到
IP是219.13.34.32的服务器上
1.首先需在域名供应商管理页面指定域名和IP的对应关系
2.WEB服务器配置好LAMP环境
3.把对应的源码分别放到/usr/local/apache/htdocs目录下,分别命名为upload和upload2
4.配置apache
#vi httpd.conf
更改成
ServerName 219.13.34.32:80
然后在文件中添加以下内容
NameVirtualHost 219.13.34.32
<VirtualHost 219.13.34.32>
ServerAdmin afd@dsf.com
DocumentRoot /usr/local/apache/htdocs
ServerName 219.13.34.32
</VirtualHost>
#
<VirtualHost 219.13.34.32>
ServerAdmin dsf@af.com
DocumentRoot /usr/local/apache/htdocs/upload
ServerName hello.abc.com
</VirtualHost>
#
<VirtualHost 219.13.34.32>
ServerAdmin adf@fda.com
DocumentRoot /usr/local/apache/htdocs/upload2
ServerName play.abc.com
</VirtualHost>
其中:NameVirtualHost 219.13.34.32很重要,没有这个,虚拟主机是不可以建立成功的。
在这里,建立了两个域名为hello.abc.com和play.abc.com的虚拟主机。
/usr/local/apache/htdocs目录是用来直接输入IP时所设置的页面目录,其他两个,是输入域
名时所访问的目录。
重启apache服务,在浏览器中输入
http://hello.abc.com

http://play.abc.com
即可访问对应不同的网站
分类: 空间域名 标签:

Linux系统信息查看命令大全

2010年11月13日 没有评论

系统

# uname -a               # 查看内核/操作系统/CPU信息
# head -n 1 /etc/issue   # 查看操作系统版本
# cat /proc/cpuinfo      # 查看CPU信息
# hostname               # 查看计算机名
# lspci -tv              # 列出所有PCI设备
# lsusb -tv              # 列出所有USB设备
# lsmod                  # 列出加载的内核模块
# env                    # 查看环境变量

资源

# free -m                # 查看内存使用量和交换区使用量
# df -h                  # 查看各分区使用情况
# du -sh <目录名>        # 查看指定目录的大小
# grep MemTotal /proc/meminfo   # 查看内存总量
# grep MemFree /proc/meminfo    # 查看空闲内存量
# uptime                 # 查看系统运行时间、用户数、负载
# cat /proc/loadavg      # 查看系统负载

磁盘和分区

# mount | column -t      # 查看挂接的分区状态
# fdisk -l               # 查看所有分区
# swapon -s              # 查看所有交换分区
# hdparm -i /dev/hda     # 查看磁盘参数(仅适用于IDE设备)
# dmesg | grep IDE       # 查看启动时IDE设备检测状况

网络

# ifconfig               # 查看所有网络接口的属性
# iptables -L            # 查看防火墙设置
# route -n               # 查看路由表
# netstat -lntp          # 查看所有监听端口
# netstat -antp          # 查看所有已经建立的连接
# netstat -s             # 查看网络统计信息

进程

# ps -ef                 # 查看所有进程
# top                    # 实时显示进程状态

用户

# w                      # 查看活动用户
# id <用户名>            # 查看指定用户信息
# last                   # 查看用户登录日志
# cut -d: -f1 /etc/passwd   # 查看系统所有用户
# cut -d: -f1 /etc/group    # 查看系统所有组
# crontab -l             # 查看当前用户的计划任务

服务

# chkconfig –list       # 列出所有系统服务
# chkconfig –list | grep on    # 列出所有启动的系统服务

程序

# rpm -qa                # 查看所有安装的软件包

分类: Linux相关 标签:

CentOS5.5+Apache2.2.15+Mysql5.1.48+PHP5.2.13 编译安装

2010年8月27日 没有评论

CentOS5.5+Apache2.2.15+Mysql5.1.48+PHP5.2.13 编译安装

httpd-2.2.15.tar.gz mysql-5.1.48.tar.gz php-5.2.13.tar.gz
请从各自的官方下载 PHP官方有发布新的5.3.2在centos5.5的gcc环境下编译会错误,所以选择比较稳定的5.2.13版本 1.yum update 检查系统更新
2.yum install gcc gcc-c++ 软件编译环境
3.yum erase httpd 卸载系统自带的httpd (apache2.2.3)
4.yum install zlib-devel libtool ncurses-devel libxml2-devel
(zlib-devel 安装apache需要,否则出错 .libtool安装mysql时候需要.同时附带了autoconf automake imake 编译mysql 5.1.48时候会出错 需要autoconf重新配置一下)
5.编译apache2.2.15

./configure –prefix=/usr/local/apache2 –enable-rewrite=shared –enable-track-vars –enable-cgi –enable-so –enable-mods-shared=all –with-config-file-path=/usr/local/apache2/conf –with-mpm=worker –enable-speling
make
make install
make clean

6.编译httpd.conf . 去掉#ServerName xxxxxx.com 前面的# 没有ServerName启动httpd服务会出错. 给LoadModule unique_id_module modules/mod_unique_id.so前面加上注释以取消加载.默认的centos5.5加载这个会启动不了httpd .
7.运行 grep -v “#” /usr/local/apache2/bin/apachectl > /etc/init.d/httpd
8.运行 chmod +x /etc/init.d/httpd (赋予httpd可以运行的权限)
9.编译/etc/init.d/httpd 在起始位置添加

#!/bin/sh
# chkconfig: 8854 85 15
# description: Apache is a World Wide Web server.

10.运行 chkconfig –add httpd
chkconfig –level 35 httpd on
11.编译mysql 5.1.48
groupadd mysql
useradd -g mysql mysql
在源码文件夹目录运行

autoreconf –force –install
./configure –prefix=/usr/local/mysql –with-charset=utf8 –with-extra-charsets=all –enable-thread-safe-client –enable-assembler –with-readline –with-big-tables –with-plugins=all –with-tcp-port=3310 –with-unix-socket-path=/var/tmp/mysql.sock –with-mysqld-ldflags=-all-static –with-client-ldflags=-all-static
make
make install
make clean

以下命令在mysql安装目录下运行

cd /usr/local/mysql
cp /usr/local/mysql/share/mysql/my-medium.cnf /etc/my.cnf
cp /usr/local/mysql/share/mysql/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
chown -R mysql .
chgrp -R mysql .
scripts/mysql_install_db –user=mysql
chown -R root .
chown -R mysql var

12.编译安装php-5.2.13 需要先安装如下包

curl-7.16.1.tar.gz freetype-2.3.12.tar.gz jpegsrc.v8b.tar.gz libpng-1.4.2.tar.gz gd-2.0.35.tar.gz libmcrypt-2.5.8.tar.gz mhash-0.9.9.9.tar.gz mcrypt-2.6.8.tar.gz
可在如下地址下载需要的软件包

http://freakshare.net/files/jmoegk3h/centos5-apache2-mysql5-php5.zip.html
http://www.missupload.com/l9byv002i59z/centos5-apache2-mysql5-php5.zip.html
http://cid-39f70fff71231d5a.office.live.com/browse.aspx/PHP/CentOS5

直接./configure 编译安装curl-7.16.1.tar.gz freetype-2.3.12.tar.gz jpegsrc.v8b.tar.gz libpng-1.4.2.tar.gz libmcrypt-2.5.8.tar.gz mhash-0.9.9.9.tar.gz
安装gd的时候需要./configure –with-png=/usr/local/lib –with-freetype=/usr/local/lib –with-jpeg=/usr/local/lib
最后编译安装 mcrypt-2.6.8.tar.gz 需要指定LD_LIBRARY_PATH路径
LD_LIBRARY_PATH=/usr/local/lib ./configure
编译php开始

./configure –prefix=/usr/local/php5 –with-gd=/usr/local/lib –with-jpeg-dir=/usr/local/lib –with-zlib –with-png-dir=/usr/local/lib –with-freetype-dir=/usr/local/lib –with-mysql=/usr/local/mysql –with-pdo-mysql=/usr/local/mysql –with-iconv –enable-mbstring –with-pear –with-apxs2=/usr/local/apache2/bin/apxs –with-libxml-dir=/usr/lib –with-curl –with-mcrypt=/usr/local/lib –with-mhash=/usr/local/lib –with-config-file-path=/etc –enable-zip –with-config-file-path=/usr/local/php5/etc
make
make install
make clean
cp php.ini-dist /usr/local/php5/etc/php.ini
打开php.ini把dll后缀改为so

13.编译httpd.conf
添加下面的代码到相应的位置
LoadModule php5_module modules/libphp5.so
AddType application/x-httpd-php .php .phtml
AddType application/x-httpd-php-source .phps
index.php
如果启用了SELinux的话还需要执行如下命令
setenforce 0
chcon -t texrel_shlib_t /usr/local/apache2/modules/libphp5.so
service httpd restart
setenforce 1

重新启动之后就可以了
14.关于Zend 直接运行解压包里的pl文件安装即可..

分类: Linux相关 标签: ,

shell常用命令汇总

2010年7月17日 评论已被关闭

Shell基本命令

几个基本的shell命令,用ssh管理主机必备。

1.ls 列出目录下的文件,不同类型的文件颜色不同,例如蓝色是文件夹,白色是文件

[root@restoretmp steph]# ls

file.html public_html test

[root@restoretmp steph]#

参数:

ls -a 列出所有文件,包括隐藏文件

[root@restoretmp steph]# ls -a

. .. .bash_logout .bash_profile .bashrc file.html public_html test

[root@restoretmp steph]#

ls -l 列出所有者 size 文件权限 修改日期

ls -R 递归列出所有子目录的内容
 

2. cd 转移目录

cd /home/steph 将转移到/home/steph

cd .. 上移一个目录

cd 回到根目录

3. 建立新文件和文件夹

touch new-filename 建立新文件

mkdir new-directory 建立新目录

4.删除文件和目录

rm filename 删除名为 filename的文件

rmdir foldername 删除名为foldername的目录

5.修改文件夹权限

chmod 755 foldername 将把名为foldername的文件夹的权限修改为755

6.修改用户

chown steph:steph file.html 把file.html的用户修改为steph:steph

2. 压缩和解压缩文件

gzip 和 gunzip

压缩:

gzip filename

文件即会被压缩,并被保存为 filename.gz

解压缩:

gunzip filename.gz

filename.gz 会被删除,而继之以 filename

可以通过命令man gip 和man gunzip获得命令的详细说明.

zip 和 unzip

要使用 zip 来压缩文件,在 shell 提示下键入下面的命令:

zip -r filename.zip filesdir

在这个例子里,filename.zip 代表你创建的文件,filesdir 代表你想放置新 zip 文件的目录。-r 选项指定你想递归地(recursively)包括所有包括在 filesdir 目录中的文件。

要解压缩 zip 文件的内容,键入以下命令:

unzip filename.zip

你可以使用 zip 命令同时处理多个文件和目录,方法是将它们逐一列出,并用空格间隔:

zip -r filename.zip file1 file2 file3 /usr/work/school

上面的命令把 file1、file2、 file3、以及 /usr/work/school 目录的内容(假设这个目录存在)压缩起来,然后放入 filename.zip 文件中。

运行FTP Wget实现上传下载

1. 用FTP将服务器上的文件上传到其他服务器

[root]$ ftp /*启用FTP客户端

ftp> open 202.103.1.2 /*打开远程服务器IP

Connected to 202.103.1.2.

220 ProFTPD 1.2.9 Server ready.

Name (218.93.205.112:qqroot): user /*输入用户名

331 Password required for oran.

Password: /*输入密码

230 User oran logged in.

put idcspy.tar.gz idcspy.tar.gz

/*这是关键,put是上传命令,第一个idcspy.tar.gz是本地文件名,第二个是远程文件名。。意思就是把本地的idcspy.tar.gz上传到远程FTP里,并且命名为idcspy.tar.gz这样,SSH就可以自己上传了。你就可以做别的事情了。

2. Wget下载文件

使用方法:

wget的使用形式是:

wget [参数列表] URL

首先来介绍一下wget的主要参数:

· -b:让wget在后台运行,记录文件写在当前目录下”wget-log”文件中;

· -t [nuber of times]:尝试次数,当wget无法与服务器建立连接时,尝试连接多少次

。比如”-t

120〃表示尝试120次。当这一项为”0〃的时候,指定尝试无穷多次直到连接成功为止,这个

设置非常有用,当对方服务器突然关机或者网络突然中断的时候,可以在恢复正常后继续

下载没有传完的文件;

· -c:断点续传,这也是个非常有用的设置,特别当下载比较大的文件的时候,如果中

途意外中断,那么连接恢复的时候会从上次没传完的地方接着传,而不是又从头开始,使

用这一项需要远程服务器也支持断点续传,一般来讲,基于UNIX/Linux的Web/FTP服务器

都支持断点续传;

· -T [number of seconds]:超时时间,指定多长时间远程服务器没有响应就中断连接

,开始下一次尝试。比如”-T

120〃表示如果120秒以后远程服务器没有发过来数据,就重新尝试连接。如果网络速度比

较快,这个时间可以设置的短些,相反,可以设置的长一些,一般最多不超过900,通常

也不少于60,一般设置在120左右比较合适;

· -w [number of seconds]:在两次尝试之间等待多少秒,比如”-w 100〃表示两次尝试

之间等待100秒;

· -Y on/off:通过/不通过代理服务器进行连接;

· -Q [byetes]:限制下载文件的总大小最多不能超过多少,比如”-Q2k”表示不能超过2K

字节,”-Q3m”表示最多不能超过3M字节,如果数字后面什么都不加,就表示是以字节为单

位,比如”-Q200〃表示最多不能超过200字节;

· -nd:不下载目录结构,把从服务器所有指定目录下载的文件都堆到当前目录里;

· -x:与”-nd”设置刚好相反,创建完整的目录结构,例如”wget -nd

http://www.gnu.org“将创建在当前目录下创建”www.gnu.org”子目录,然后按照服务器

实际的目录结构一级一级建下去,直到所有的文件都传完为止;

· -nH:不创建以目标主机域名为目录名的目录,将目标主机的目录结构直接下到当前目

录下;

· –http-user=username

· –http-passwd=password:如果Web服务器需要指定用户名和口令,用这两项来设定;

· –proxy-user=userna

分类: Linux相关 标签: ,

超实用的Linux/Unix快捷键大汇总

2010年7月9日 没有评论

近期在工作中发现,许多同事,尤其是我们的PHP开发者,基本不会用Linux/unix下的快捷方式,严重影响工作效率,所以特撰写此文,每个用法后我会详细注释。

下述所有命令在Linux/unix的shell下有效,这里以bash为主。如有出入,以你自己的服务器为准。本文所指的Linux主要指RHEL/CentOS,unix指的是FreeBSD,这也是服务器中用得最多的版本。

Ctrl + a 切换到命令行开始

这个操作跟Home实现的结果一样的,但Home在某些unix环境下无法使用,便可以使用这个组合;在Linux下的vim,这个也是有效的;另外,在windows的许多文件编辑器里,这个也是有效的。

Ctrl + e 切换到命令行末尾

这个操作跟END实现的结果一样的,但End键在某些unix环境下无法使用,便可以使用这个组合;在Linux下的vim,这个也是有效的;另外,在windows的许多文件编辑器里,这个也是有效的。

Ctrl + l 清除屏幕内容,效果等同于clear

Ctrl + u 清除剪切光标之前的内容

这个命令很有用,在nslookup里也是有效的。我有时看见同事一个字一个字的删除shell命令,十分崩溃!其实完全可以用一个Ctrl + u搞定。

Ctrl + k 剪切清除光标之后的内容

Ctrl + y 粘贴刚才所删除的字符

此命令比较强悍,删除的字符有可能是几个字符串,但极有可能是一行命令。

Ctrl + r 在历史命令中查找 (这个非常好用,输入关键字就调出以前的命令了)

这个命令我强烈推荐,有时history比较多时,想找一个比较复杂的,直接在这里,shell会自动查找并调用,方便极了

Ctrl + c 终止命令

Ctrl + d 退出shell,logout

Ctrl + z 转入后台运行

不过,由Ctrl + z转入后台运行的进程在当前用户退出后就会终止,所以用这个不如用nohup命令&,因为nohup命令的作用就是用户退出之后进程仍然继续运行,而现在许多脚本和命令都要求在root退出时仍然有效。

下面再被充下大家不是太熟悉,我用得比较多的操作方式:

!! 重复执行最后一条命令

history 显示你所有执行过的编号+历史命令。这个可以配合!编辑来执行某某命令

↑(Ctrl+p) 显示上一条命令

↓(Ctrl+n) 显示下一条命令

!$ 显示系统最近的一条参数

最后这个比较有用,比如我先用cat /etc/sysconfig/network-scripts/ifconfig-eth0,然后我想用vim编辑。一般的做法是先用↑ 显示最后一条命令,然后用Home移动到命令最前,删除cat,然后再输入vim命令。其实完全可以用vim !$来代替。

开发和管理员的话,掌握以上用法后,基本上工作就很有效率了;用到最后,你会不经意发现,弹指之间,许多复杂的指令你会很轻松的搞定。

附录:Linux下的桌面环境的快捷方式

以下指令在Linux/unix的桌面环境(gnome)下有效,如有出入以你自己的服务器为准:

Alt + F1 类似Windows下的Win键,在GNOME中打开”应用程序”菜单(Applications)

Alt + F2 类似Windows下的Win + R组合键,在GNOME中运行应用程序

Ctrl + Alt + D 类似Windows下的Win + D组合键,显示桌面

Ctrl + Alt + L 锁定桌面并启动屏幕保护程序

Alt + Tab 同Windows下的Alt + Tab组合键,在不同程序窗口间切换

PrintScreen 全屏抓图

Alt + PrintScreen 当前窗口抓图

Ctrl + Alt + → / ← 在不同工作台间切换

Ctrl + Alt + Shift + → / ← 移动当前窗口到不同工作台

Ctrl+Alt+Shift+Fn 终端N或模拟终端N(n和N为数字1-6)

Ctrl+Alt+Shift+F7 返回桌面

Ctrl+Alt+Shift+F8 未知(终端或模拟终端)

窗口操作快捷键

Alt + F4 关闭窗口

Alt + F5 取消最大化窗口 (恢复窗口原来的大小)

Alt + F7 移动窗口 (注: 在窗口最大化的状态下无效)

Alt + F8 改变窗口大小 (注: 在窗口最大化的状态下无效)

Alt + F9 最小化窗口

Alt + F10 最大化窗口

Alt + Space 打开窗口的控制菜单 (点击窗口左上角图标出现的菜单)

应用程序中的常用快捷键

下面这些并不适用于所有程序。可以和Windows下的快捷键类比下:

Ctrl+N 新建窗口

Ctrl+X 剪切

Ctrl+C 复制

Ctrl+V 粘贴

Ctrl+Z 撤销上一步操作

Ctrl+Shift+Z 重做刚撤销的一步操作

Ctrl+S 保存

文件浏览器

Ctrl+H 显示隐藏文件(切换键)

Ctrl+T 新建标签

Ctrl+Page Up 上一个标签

Ctrl+Page Down 下一个标签

Alt+N 切换到第N个标签(N为数字)



分类: Linux相关 标签:

Linux 常用命令使用方法大搜刮

2010年6月5日 没有评论

1.# 表示权限用户(如:root),$ 表示普通用户
开机提示:Login:输入用户名
password:输入口令   用户是系统注册用户成功登陆后,可以进入相应的用户环境.
退出当前shell,输入:exit

2.useradd netseek 添加一个netseek用户
passwd netseek  给netseek这个用户设置密码.
(/etc/passwd /etc/group)
userdel netseek 删除账号
userdel -r netseek 删除账号连同自家目录.
[更详细的操作请参阅man page,和账号管理篇]

3.查看命令
ls -l                显示文件列表
ls -al        -a 显示所有档案及目录 (ls内定将档案名或目录名称开头为”.”的视为隐藏档,不会列出)
ls -al |grep ‘^d’   显示目录
ls -al |grep ‘^[^d]‘ 在一个目录中查询不包含目录的所有文件
ls -sh        (man ls 查看man帮助.)

linux几种文件类型:
d    表示此文件是一个目录
-    表示此文件是一个普通文件
b    表示此文件是一个特殊的块设备I/O文件
c    表示此文件是一个特殊的字符设备I/O文件
l    表示此文件是一个连接文件。在其文件名称后紧跟与它连接的文件路径及名称

file 命令通过探测文件内容判断文件类型

4.建立文件和目录
touch 1.txt
cat > 2.txt (用定向符创建文件,填写内容后,按ctrl+d保存内容)
mkdir mywork 建立mywork这个目录

5.拷贝文件或目录
cp filename1 filename2
cp -r dir1 dir2 复制目录
cp -rf 参数f是删除已经存在的目标文件而不提示
cp -i  参数i和f相反,在覆盖目标文件之前将给出提示要求用户确认,回答y时目标文件将被覆盖,是交互式拷贝.

6.删除文件和目录(删除文件或目录都可以用rm搞定)
rm 1.c //将1.c这个文件删除
rm -rf (强制删除文件或目录,删除时不提示.)

7.移走目录或者改文件名
mv [opitons] 源文件或目录   目标文件或目录
[options]主要参数
-i:交互方式操作,如果mv操作将导致对已存在的目标文件的覆盖,此时系统询问是否重写,要求用户回答“y”或“n”,
这样可以避免误覆盖文件.
-f:禁止交互操作。mv操作要覆盖某个已有的目标文件时不给任何指示,指定此参数后i参数将不再起作用。
mv hello ../ 将hello目录或者文件移动上一级.

8.alias 别名
alias dir=’ls -l’   输入dir,其实就相当于执行了ls -l

9.权限的控制(rwx 421)
chmod +x hello.sh 赋于可执行权限.
(详细介绍一下权限的控制)
chmod 命令 权限修改 用法:chmod 一位8进制数 filename (rwx 421)
eg: chmod u+x filenmame      只想给自己运行,别人只能读
chown netseek.netseek mydir  改变用户属组

u:表示文件所有者
g:表示同组用户
o:表示其它用户
a:表示所有用户
opt则是代表操作,可以为:
+:添加某个权限
-:取消某个权限
=:赋予给定的权限,并取消原有的权限
而mode则代表权限:
r:可读 4
w:可写 2
x:可执行 1

10.pwd 显示当前目录完整路径和改变目录
cd netseek 进入netseek这个目录
cd 退出当前目录
cd ../ 进入上一级目录.
cd – 返回上一次目录
cd ~ 返回主目录

11. cat,more,less 命令
将某个文件的内容显示出来,两个命令不同的是:cat 把文件内容一直打印出来,而more则分展显示.
less 可以上下翻滚查看内容.
cat > 1.txt 可以填写或者复制内容,按ctrl+d保存
cat 1.c
more 1.c
head -n filename 显示第N行的内容
tail -n filename 显示后N行的内容
tail -n 20 /var/log/message 显示最新的20行日志

12.设置linux时间和日期
date 命令(“date MMDDhhmmYYYY.ss”)
2006年7月24日12:37 ,30秒
date 072412372006.30
date -s 20:30:30 #设置系统时间为20: 30:30
date -s 2006-7-24 #设置系统时期为2006-7-24
clock -r #对系统Bios中读取时间参数
clock -w #将系统时间(如由date设置的时间)写入Bios

13.查看找文件(find,grep,awk更多的请参照man page或shell编程专题讲解)
几种介绍:
find 路径  -name 文件名
find /etc -name named.conf
locate 通过文件名搜索文件的工具(要先通过updatedb建立索引数据库)
localte named.conf
whereis 是寻找二进制文件,同时也会找到其帮助文件
which 和where 相似,只是我们所设置的环境变量中设置好的路径中寻找;比如;

14.查杀进程
ps aux
ps -ef |grep
kill -9
看看哪个进程占用的内存最大
ps -aux|sort +5n

将程序放在前后台执行
cp file1 file2 &
&与ctrl+z 你可以使用&或ctrl+z来将命令放在后台执行.
fg 是将放在后台执行的程序再放回前台.
jobs

15.dd命令备份
dd if=”input_file” of=”out_file” bs=”block_size” count=”number”
参数:
if:就是input file可以是设备
of:就是output file也可以是设备
bs:规划的一个block的大小,如果没有设定时,预设是512bytes
count:多少个bs的意思.

dd if=/etc/password of=/tmp/passwd.bak 备份

16.mount 加载一个硬件设备
用法:mount [参数] 要加载的设备 载入点
eg: mount /dev/cdrom
cd /mnt/cdrom //进入光盘目录
u盘:
mkdir /mnt/usb;(注:创建挂载目录)
mount /mnt/sda1 /mnt/usb;(注:挂载U盘)
现在就可以使用U盘了,在/mnt/usb目录下的内容就是U盘里的内容了;
使用完后,用以下命令卸载U盘即可。
umount /mnt/usb
mount     列出系统所有的分区
mount -t iso9660 /dev/cdrom /mnt/cdrom   挂载光盘
mount -t vfat /dev/fd0 /mnt/floppy       挂载软盘
mount -t vfat -o iocharset=utf8,umask=000 /dev/hda2 /mnt/hda2   挂载fat32分区
mount -t ntfs -o nls=utf8,umask=000 /dev/hda3 /mnt/hda3         挂载ntfs分区
Linux-NTFS Project: http://linux-ntfs.sourceforge.net/
umount /mnt/hda3 缷载
注:挂载设备前,请先fdisk -l 看一下.

17.su在不退出登陆的情况下,切换到另一个身份
用法: su -l 用户名(如果用户名缺省,则切换到root状态)
eg:su -l netseek (切换到netseek这个用户,将提示输入密码),加上-表示切换到用户的环境变量.

sudo 利用他可以执行root执行的权限

18.whoami,id,w,lastlog,users,groups
w       查看用户登陆信息
who     查看当前登陆用户
last    最近一个月用户登陆情况
lastlog 检查某特定用户上次登录的时间,并格式化输出上次登录日志/var/log/lastlog的内容
whoami  确认自己身份.
id      打印出自己的UID以及GID.(UID:用户身份唯一标识.GID:用户组身份唯一标识.每一个用户只能有一个唯一的UID和GID.)
users
groups  用户所归属的用户组查询;
finger -l netseek root
finger -s 或者直接finger
可以让使用者查询一些其他使用者的资料
eg: finger //查看所用用户的使用资料
finger root //查看root的资料

19.用户用过的命令和执行历史执行的命令
history 显示用户过去命用的命令
!!执行最近一次的命令

20.uname 查看linux系统信息
参数:-a 所有信息 -r 版本号 -n 主机名

21.建立软连接
ln [-sf] source target
ln souce-file hard-link
ln -sf source-file soft-link
s表示软连接,f表示,若有同名文件在,则将它覆盖过去.
注:硬链接不能为目录创建,只有文件才能创建硬链接。

22.查看目录
du -sh   目录或者文件
du -m    du系统默认输出是以KB,以参数-m表示以MB显示.
cat /etc/fstab   查看分区列表
fdisk -l
df -h
df -ah

23.查看linux系统占用的资源(top,free,uptime)
top   查看后台程序,监控系统性能
top -d 2 每两秒列新一次
top -d -2 -p3690 查看某个PID
top -b -n 2 >/tmp/top.txt 将top的信息进行2次,然后将结果输出到/tmp/top.txt

free -m 查看系统内存使用情况

uptime  显示目前系统开机时间(查看开机多久,多少人登陆,过去1,5,15分钟系统的负载)

24.文件比软件:
cmp  cmp(“compare”的缩写)命令用来简要指出两个文件是否存在差异,它的使用权限是所有用户
diff diff命令用于两个文件之间的比较,并指出两者的不同,它的使用权限是所有用户

25.远程操作与文件传输
ssh user@remote.machine
scp user@remote.machine:/remote/path /local/path
scp /local/path user@remote.machine:/remote/path

26.编译c/c++文件
gcc
gcc -v 查看GCC版本
gcc -o test test.c 2>errfile 编译test.c时若有错误信息,则将错误信息重定向到errfile

27.chattr +i filename 禁止删除,chattr -i filename 取消禁止
lsattr 查看隐藏档属性

28.自动化执行
at 执行一次
crontab 定时循环执行程序
crontab 介绍
1 以root登录
2 # crontab -e
3 加入一行
1 */12 * * * /usr/sbin/ntpdate pool.ntp.org
分钟 (0-59)
小時 (0-23)
日 期 (1-31)
月份 (1-12)
星期 (0-6)//0代表星期天

29.关机和重启:
shutwond [-t 秒数] [-rkhncff] 时间 [警告信息]
-t 秒数:设置在切换至不同的runlevel之前,警告和删除两信号之彰间的延迟时间(秒)
-k 发出警告信息,但不是真的要shutdown
-r shutdown这后重新开机
-h shutdown这后开机
-n 不经过init,由shutdown命令本身来做开机工作(不建议你使用)
-f 重新开机时,跳过fsck指令,不检查文件系统.
-F 重新开机时,强迫做fsck检查.
-c 将已经正在shutdown的动作取消
shutdown -h now 立刻关机,其中now相当于时间为0,halt,poweroff也可以关机,或者直接init 0
shutdown -h 20:30  系统将在今晚的8:30关机
shutdown -h +10    系统再过十分钟后自动关机.
shutdown -t3 -r now  立刻重新开机,但在警告和删除processes这间,
shutdown -k now  ’Hey! Go away! now…’ 发出警告信息,但没有真的关机.

reboot:
shutdown -r now 几乎与reboot相同,不关建议用reboot执行如下:
shutdown -r +30 ‘The system wiil reboot’
shutdown -r +10 ‘Hey!Go away!’  10分钟后系统重启.
#sync; sync; sync; reboot   注:sync将数据同步写入硬盘
halt命令相当于shutdown -h now ,表示立刻关机。
reboot命令相当于shutown -r now ,表示立刻重起。

30.如何改变启动模式运行级别
vi /etc/inittab
将5改成3,启动后就可以变成字符模式。
startx 或者 init 5 就可以进入图形化界面.
runlevel 显示当前运行级别

如何切换至单用户模式
利用telinit或init(其实telinit只是一个synbol link to init)
telinit 1 或者 init S 即可,当然telinit S也是可以的.

如何使ctrl+alt+del 三键失效的方法
#vi /etc/inittab
在ca::ctrlaltdel:/sbin/shutdonw -t3 -r now之前加上注释#
然后执行#telinit q ,参数q是要telinit重新检查一次/etc/inittab

31.TAB  巧用tab键,当你不知道文件或命令的全名是请连续按两下tab键.

32.clear 清屏

33.dmesg |more 显示开机信息(查看系统启动时硬件信息)

34.改变程序执行的优秀级
nice    设置优先权 nice -n -5 vi & 用root给一个nice值为-5,用于执行vi
renice  调整已存在优先权

35.模块相关的命令
lsmod 显示已经载入系统的模块
depmod 分析可载入系统的相依性
modinfo 显示kernel模块的信息
insmod  载入模块
modprobe 自动处理可载入模块
rmmod    删除模块

36.chkconfig –list 显示各种服务的状态,利用chkconfig可以轻松管理init脚本.

37.linux的几种解压缩命令
compress aaa  将aaa文件压缩成为aaa.Z
compress -d aaa.z 将aaa.z文件压缩成aaa

gzip aaa 压缩命令
gzip -d aaa.gz  解压命令

bzip2 -z filename 压缩,同上加-d参数解压
bzcat filename.bz 查看压缩文件内容

tar czvf aaa.tar.gz aaa 将目录aaa压缩成aaa.tar.gz
tar -N ’2007/03/01′ -zcvf home.tar.gz /home 在/home当中,比2007/03/01新的文件才备份.
tar –exclude /home/cao -zxvf myfile.tar.gz /home/* /etc 要备份/home,/etc,但不要/home/cao
cd /tmp; tar -cvf -/etc | tar -xvf – 将/etc/打包后直接解开/tmp底下,而不产生文件.
tar zxvf aaa.tar.gz 解压缩命令.
tar jxvf aaa.tar.bz2 解压命令
tar zxvf aaa.tar.gz -C /var/www 将aaa.tar.gz解压到/var/www目录下
cpio -covB > [file|device] 备份
cpio -icduv < [file|device] 还原

38.网络命令
ifconfig 显示或设置网络设备,可以查看当前ip,类似于windows里的ipconfig
service network restart(/etc/rc.d/init.d/network restart) 重启网卡
ifdown eth0 关闭网卡
ifup eth0 开启网卡
route -n 查看路由表
route add -net 192.168.20.1 netmask 255.255.255.0 dev eth0

netstat 查看网络连接情况
netstat -i 显示网卡运行情况
netstat -r 查看主机的路由列表

traceroute

hostname 显示主机名
hostname -i 显示当前主机名的IP.

39.系统集成管理菜单.
setup   系统服务管理命令
ntsysv  设置系统服务

40.fdisk /mbr 删除GRUB

41.数据库启动
启动mysql:
service mysqld start(/etc/rc.d/init.d/mysqld start)
mysql -uroot -p 输入密码即可操作mysql数据库.

启动Oracle
su – oracle
$lsnrctl stop
$lsnrctl start
sqlplus /nolog
conn /as sysdba(connected)
startup

42.安装软件包
rpm包安装:
rpm -ivh xxx.rpm         安装rpm包
rpm -qa –last | less    根据安装日期显示已经安装的包
rpm -qa |grep mysql -i   查询系统是否安装mysql包(-i,忽略大小写)
rpm -e                   删除安装的软件包
rpm -e mysql* –nodpes   强制删除相关的软件包
rpm –test               测试安装
rpm -qi                  查询mysql套件的说明资料
rpm -qpl xxx.rpm         查看rpm包内含的内容.
rpm -qc[d]               设定档与说明档
rpm -Uvh                 升级安装
rpmbuild –bb SPECS/xxx.spec 重新装将xxx.spec编译成rpm包.
rpmbuild –rebuild packagename.src.rpm 重新把.src.rpm编译成rpm包.

源码编译安装(经典)
./configure              检查系统信息(./configure –help | more 帮助信息,可以看到相关的参数设定)
make clean               清除之前留下的文件
make                     编译
make install             安装
注:源码包安装,一般先将文件解压,安装过程大致上面几步,具体说明一般见解压后目录里的(INSTALL,READEME说明.)

分类: Linux 标签:

Linux视频教程下载(非常好,强烈推荐)

2010年3月20日 没有评论

一款对Linux学习有帮助的Linux视频教程全新提供永久下载。很多讲的内容都需要大家去掌握的,在Linux下的基础的方方面面都讲到了。有图像有声音,为大家的学习带来新的精神。

注:建议用下载工具下载,如网际快车。如无法连接下载请稍候再连接,保证能下。

下载地址:一共四集,请全部下载完。

第一集:ftp://FTP_hllinux:123456@211.95.73.26/linux视频1.rar
第二集:ftp://FTP_hllinux:123456@211.95.73.26/linux视频2.rar
第三集:ftp://FTP_hllinux:123456@211.95.73.26/linux视频3.rar
第四集:ftp://FTP_hllinux:123456@211.95.73.26/linux视频4.rar

Linux实用培训学习教程1.0(最终版)

本书是为广大Linux学习者制做的,本书内容基础,语言简短简洁,也节选了一些比较经典而且一定要了解的Linux知识,循序渐进的介绍Linux相关知识,从入门到提高,希望对所有学习Linux的朋友都有帮助.请选择其中之一下载地址即可.

下载地址一:ftp://FTP_hllinux:123456@211.95.73.26/hl/Linux实用培训学习教程1.0(最终版).chm

下载地址二:http://www.linux286.com/linux/linux.chm

分类: 琐碎收藏 标签:

用SSH(Shell)上传文件到远程服务器的方法

2010年3月7日 没有评论

假设要上传的压缩包在SSH所在服务器的zip目录中,形如:zip/testupload.tar.gz ,远程服务器IP地址:125.211.218.17 远程服务器FTP用户:usename  FTP密码为:123456

我们首先登录SSH并转到zip目录下,当然就是一路的ls和cd命令。如:

cd code /*转到code目录
ls /*列出该目录所有文件

下面就是利用SSH上传的命令了:

[tyche]$ ftp /* ftp命令,启用FTP客户端
ftp> open  125.211.218.17 /*open命令,打开远程服务器IP
Connected to 125.211.218.17   /*出现连接服务器的信息
220 ProFTPD 1.2.9 Server ready.  /*出现连接服务器的信息
Name (125.211.218.17:root): username /*输入FTP用户名
331 Password required for oran.
Password: 123456 /*输入密码
230 User oran logged in.  /*已经登录完毕
put testupload.tar.gz testupload.tar.gz
/*这是关键,put是上传命令,第一个testupload.tar.gz是本服务器文件名,第二个是远程文件名。就是说把本服务器上的testupload.tar.gz 上传到远程FTP里,并且命名为testupload.tar.gz 这样。

这时候SSH就可以自己上传了。你就可以做别的事情了。待会儿回来就会看到成果了。国外服务器多传的速度是很快的。

分类: Linux相关 标签: , ,

安装MYSQL出现checking for termcap functions library… configure: error: No curses/termcap library found

2010年2月27日 没有评论

如果编译时出现了以下错误:
checking for tgetent in -ltermcap… no
checking for termcap functions library… configure: error: No curses/termcap library found

说明 curses/termcap 库没有安装,去下载一个ncurses-5.6.tar.gz,

wget http://ftp.gnu.org/pub/gnu/ncurses/ncurses-5.6.tar.gz
tar zxvf ncurses-5.6.tar.gz
cd ncurses-5.6
./configure –prefix=/usr –with-shared –without-debug
make
make install clean
然后再重新编译Mysql进行安装。

分类: Linux相关 标签: ,

Myql make 报【exec: g++: not found】错误【已解决】 – MySQL – ChinaUnix.net

2010年2月9日 没有评论

使用

./configure –with-named-curses-libs=/usr/lib/libncursesw.so.5

配置
然后在make的时候报错:
ude -I../include -I.    -O    -fno-implicit-templates -fno-exceptions -fno-rtti -c -o my_new.o my_new.cc
../depcomp: line 512:
make[1]: *** [my_new.o] Error 127
make[1]: Leaving directory `/home/mysql-5.1.22-rc/mysys’
make: *** [all-recursive] Error 1

[1]+  Exit 2                  make

源码是mysql-5.1.22-rc
系统 Foreda 8
——————————
解决办法,安装Packages/gcc-c++-4.1.2-33.i386.rpm

分类: Linux相关 标签: