2005年05月08日

rundll32 netplwiz.dll,UsersRunDll

2005年02月24日

 ./configure –prefix=/usr/local/pureftpd –with-mysql=/usr/local/mysql –with-paranoidmsg –with-shadow –with-welcomemsg –with-uploadscript –with-quotas –with-cookie –with-pam –with-virtualhosts –with-virtualroot –with-diraliases –with-sysquotas –with-ratios –with-ftpwho –with-throttling –with-language=simplified-chinese –with-everything –with-largfile

2005年01月28日

有时候某些目录下的文件需要增加认证,Apache缺省的认证模块都是很完备的,以下就是一个通过.htaccess文件增加用户认证的例子。即使对于虚拟主机用户也可以通过上传一些文件来实现认证控制。

首先用htpasswd创建一个密码文件:比如文件名叫做my.passwd
/home/apache/bin/htpasswd -c -b my.passwd myusername mypassword
如果增加帐号:
/home/apache/bin/htpasswd -b my.passwd anotherusername anotherpassword

将my.passwd上传到一个非发布路径下。
比如你的物理WEB根目录的上一级
/home/apache/conf/my.passwd

创建 .htaccess
AuthName “My Authorization Directory”
AuthType Basic
AuthUserFile /home/apache/conf/my.passwd
Require valid-user

将这个文件上传到你需要进行用户认证的目录:
/home/apache/htdocs/admin/.htaccess

这样这个目录的访问就需要认证了。

2005年01月27日

安装mysql
——————————————————–
mysql 4.0.23 install

tar -vxzf mysql-standard-4.0.23-pc-linux-i686.tar.gz
mv mysql-standard-4.0.23-pc-linux-i686 /usr/local/
ln -s /usr/local/mysql-standard-4.0.23-pc-linux-i686

/usr/local/mysql
groupadd mysql
useradd mysql
passwd mysql
cd /usr/local/mysql
scripts/mysql_install_db –user=mysql
chmod -R root .
chmod -R mysql data
chgrp -R mysql .
bin/mysqld_safe –user=mysql &
./mysqladmin -u root password ‘password’ #修改mysql的

root密码

cp support-files/mysql.server /etc/rc.d/init.d/mysqld
chkconfig –add mysqld
ntsysv

重新启动 #发觉不重启用/etc/rc.d/init.d/mysqld

start有问题

重启好用
/user/local/mysql/bin/mysqld -h localhost -u root -p 登

然后用show databases;查看安装了几个库
用status;来查看安装状态;
——————————————————–

安装tomcat
——————————————————–

-

./j2sdk-1_4_2_05-linux-i586-rpm.bin
rpm -ivh j2sdk-1_4_2_05-linux-i586.rpm
ln -s /usr/java/j2sdk1.4.2_05 /usr/local/jdk
mv jakarta-tomcat-5.0.28 /usr/local/
ln -s /usr/local/jakarta-tomcat-5.0.28 tomcat
vi /usr/local/tomcat/bin/catalina.sh
添加:
 JAVA_HOME=/usr/local/jdk/
 CATALINA_HOME=”/usr/local/tomcat/”
 JAVA_OPTS=”-Xms256m -Xmx256m”
启动tomcat
 /usr/local/tomcat/bin/startup.sh
添加tomcat用户
 groupadd tomcat
 useradd -g tomcat -c “Tomcat User” -d

/usr/local/tomcat tomcat
 chown -R tomcat:tomcat /usr/local/tomcat
 chown -R tomcat:tomcat

/usr/local/jakarta-tomcat-5.0.28


使用tomcat用户启动tomcat
 su – tomcat -c /usr/local/tomcat/bin/startup.sh
访问8080
——————————————————–

—-

安装GD
——————————————————–

—-

tar -zxfv zlib-1.2.2.tar.gz
cd zlib-1.2.2
./configure –prefix=/usr/local/zlib2
make
make install

tar -zxvf jpegsrc.v6b.tar.gz
cd jpeg-6b
./configure –prefix=/usr/local/jpeg6
make
make install-lib
mkdir /usr/local/jpeg6
mkdir /usr/local/jpeg6/include
mkdir /usr/local/jpeg6/lib
make install-lib
make install
mkdir /usr/local/jpeg6/bin
mkdir /usr/local/jpeg6/man
mkdir /usr/local/jpeg6/man/man1
make install


tar -zxvf freetype-2.1.9.tar.gz
cd freetype-2.1.9
./configure –prefix=/usr/local/freetype2
make
make install

tar -zxvf libpng-1.2.8.tar.gz
cd libpng-1.2.8
cd scripts/
mv makefile.linux ../makefile
make
make install


tar -zxvf gd-2.0.33.tar.gz
cd gd-2.0.33
 ./configure –prefix=/usr/local/gd2

–with-zlib=/usr/local/zlib2/ –with-png
–with-jpeg=/usr/local/jpeg6/

–with-freetype=/usr/local/freetype2/
make
make install
————————————————-

—————————————————
安装openssl

tar -zxvf openssl-0.9.7b.tar.gz
cd openssl-0.9.7b
./config –prefix=/usr/local/openssl
make
make install

——————————————————–

安装apache2.0.52

tar zxvf httpd-2.0.52.tar.gz
cd httpd-2.0.52
./configure –prefix=/usr/local/apache2 –enable-so

–enable-ssl –with-ssl=/usr/local/openssl
make
make install


—————————————————–


—————————————————–
安装PHP

tar zxvf php-4.3.10.tar.tz
cd php-4.3.10
./configure –prefix=/usr/local/php

–with-apxs2=/usr/local/apache/bin/apxs

–with-jpeg-dir=/usr/local/jpeg6 –with-png

–with-freetype-dir=/usr/local/freetype2

–with-zlib-dir=/usr/local/zlib2

–with-mysql=/usr/local/mysql –with-gd=/usr/local/gd2

–enable-trace-vars –enable-ftp
make
make install
cp php.ini-dist /usr/local/lib/php.ini
vi /usr/local/apache/conf/httpd.conf
加入
 AddType application/x-httpd-php .php
 AddType application/x-httpd-php-source .phps
 AddType application/x-httpd-php .php3

——————————————————

——————————————————
jk2

tar -xzvf 

jakarta-tomcat-connectors-jk2-src-current.tar.gz
cd jakarta-tomcat-connectors-jk2-2.0.4-src/
cd jk/native2
./buildconf.sh
./configure –with-apxs2=/usr/local/apache/bin/apxs
make
cp build/jk2/apache2/mod_jk2.so

/usr/local/apache/modules/
vi /usr/local/apache/conf/httpd.conf
加入 LoadModule jk2_module modules/mod_jk2.so

vi /usr/local/tomcat/conf/jk2.properties
加入 

handler.list=apr,channelSocket,request,channelJni
 channelSocket.port=8009

vi /usr/local/apache/conf/workers2properties
加入 [shm]
 file=/usr/local/apache/logs/shm.file
 size=1048576

 [channel.socket:localhost:8009]
 port=8009
 host=127.0.0.1

 [ajp13:localhost:8009]
 channel=channel.socket:localhost:8009

 [uri:/sky/*]
 worker=ajp13:localhost:8009

——————————————————-
先建立一个 CA 的证书, 
首先为 CA 创建一个 RSA 私用密钥, 
[S-1] 
openssl genrsa -des3 -out ca.key 1024 
系统提示输入 PEM pass phrase,也就是密码,输入后牢记它。

 
生成 ca.key 文件,将文件属性改为400,并放在安全的地方。 
[S-2] 
chmod 400 ca.key 
你可以用下列命令查看它的内容, 
[S-3] 
openssl rsa -noout -text -in ca.key 

利用 CA 的 RSA 密钥创建一个自签署的 CA 证书(X.509结构)

 
[S-4] 
openssl req -new -x509 -days 3650 -key ca.key -out

ca.crt 
然后需要输入下列信息: 
Country Name: cn 两个字母的国家代号 
State or Province Name: An Hui 省份名称 
Locality Name: Bengbu 城市名称 
Organization Name: Family Network 公司名称 
Organizational Unit Name: Home 部门名称 
Common Name: Chen Yang 你的姓名 
Email Address: sunstorm@263.net Email地址 
生成 ca.crt 文件,将文件属性改为400,并放在安全的地方。 
[S-5] 
chmod 400 ca.crt 
你可以用下列命令查看它的内容, 
[S-6] 
openssl x509 -noout -text -in ca.crt 


下面要创建服务器证书签署请求, 
首先为你的 Apache 创建一个 RSA 私用密钥: 
[S-7] 
openssl genrsa -des3 -out server.key 1024 
这里也要设定pass phrase。 
生成 server.key 文件,将文件属性改为400,并放在安全的地

方。 
[S-8] 
chmod 400 server.key 
你可以用下列命令查看它的内容, 
[S-9] 
openssl rsa -noout -text -in server.key 

用 server.key 生成证书签署请求 CSR. 
[S-10] 
openssl req -new -key server.key -out server.csr 
这里也要输入一些信息,和[S-4]中的内容类似。 
至于 ‘extra’ attributes 不用输入。 

你可以查看 CSR 的细节 
[S-11] 
openssl req -noout -text -in server.csr 

下面可以签署证书了,需要用到脚本 sign.sh 
[S-12] 
sign.sh server.csr 
就可以得到server.crt。 
将文件属性改为400,并放在安全的地方。 
[S-13] 
chmod 400 server.crt 

删除CSR 
[S-14] 
rm server.csr 

拷贝server.crt 和 server.key 到 /usr/local/apache/conf

apachectl startssl

2005年01月22日

———————————————————-建过程

CREATE OR REPLACE PACKAGE TEST2 IS
 PROCEDURE PROC_TEST(p_id in number,p_name out varchar2,p_count out varchar2);
END;


CREATE OR REPLACE PACKAGE BODY TEST2 IS

 PROCEDURE PROC_TEST(p_id in NUMBER,p_name out varchar2,p_count out varchar2) is
 BEGIN
  SELECT count(*) INTO p_count
    FROM TEST1
    WHERE ID = p_id;
    if p_count=1 then
       p_name:=’ok’;
       else p_name:=’error’;
       end if;  
    END;
   
END;

————————————————————建表

– Create table
create table TEST1
(
  ID   NUMBER(16) not null,
  NAME VARCHAR2(30) not null
)
tablespace FJDC_USER
  pctfree 10
  initrans 1
  maxtrans 255
  storage
  (
    initial 64K
    minextents 1
    maxextents unlimited
  );

<?
$conn = OCILogon(“fjdc_user”,”fjdc_user”,”ora9″);
echo “$conn<br>”;

if ($conn)
{echo “连接成功<br>”;}

else{echo “连接失败”;}
$id = “2″;                       
$name = “”;
$sql_sp = “BEGIN TEST2.PROC_TEST(‘$id’,:name,:acount); END;”;

//Parse
$stmt = OCIParse($conn, $sql_sp);

//执行绑定
//OCIBindByName($stmt, “:id”, $id, 16);           //参数说明:绑定php变量$id到位置:id,并设定绑定长度16位
OCIBindByName($stmt, “:name”, $name, 10);
OCIBindByName($stmt,”:acount”,$acount,10);

//Execute
OCIExecute($stmt);

//结果
echo “name is : $name<br>$acount”;

?>

2004年12月09日

# 清除预设表 filter 中,所有规则链中的规则
iptables -F
# 清除预设表 filter 中,使用者自订链中的规则
iptables -X

# 清除mangle表中,所有规则链中的规则
iptables -F -t mangle
# 清除mangle表中,使用者自订链中的规则
iptables -t mangle -X

# 清除nat表中,所有规则链中的规则
iptables -F -t nat
# 清除nat表中,使用者自订链中的规则
iptables -t nat -X


iptables -P INPUT DROP
iptables -P OUTPUT DROP
iptables -P FORWARD DROP
iptables -A INPUT -p tcp –dport 80 -j ACCEPT
iptables -A INPUT -p tcp –dport 22 -j ACCEPT
iptables -A INPUT -p tcp –dport 21 -j ACCEPT
iptables -A INPUT -p tcp –dport 1521 -j ACCEPT

iptables -A INPUT -d 127.0.0.1 -j ACCEPT
/etc/rc.d/init.d/iptables save

2004年11月17日

所需软件:
 Apache2.0.49 for Win32
 PHP4.3.9 fro Win32 Apache
jakarta-tomcat-connectors-jk2.0.4-win32-apache2.0.49.zip
jakarta-tomcat-5.0.28.zip
j2sdk-1_4_2_05-windows-i586-p.exe
按照默认安装Apache
解压缩PHP到C:\Program files\php目录下
 将php下的php4ts.dll和php\dlls\下的所有文件复制到c:\winnt\system32下
 将php下的php.ini-dist复制到c:\winnt\system32下并改名为php.ini
 打开php.ini
 找到extension_dir =修改为extension_dir = “C:\Program Files\PHP\extensions\”
 找到;extension=php_bz2.dll->;extension=php_zip.dll这段修改为
 extension=php_bz2.dll
 extension=php_cpdf.dll
 extension=php_crack.dll
 extension=php_curl.dll
 extension=php_db.dll
 extension=php_dba.dll
 extension=php_dbase.dll
 extension=php_dbx.dll
 extension=php_domxml.dll
 extension=php_exif.dll
 extension=php_fdf.dll
 extension=php_filepro.dll
 extension=php_gd2.dll
 extension=php_gettext.dll
 extension=php_hyperwave.dll
 extension=php_iconv.dll
 ;extension=php_ifx.dll
 ;extension=php_iisfunc.dll
 extension=php_imap.dll
 extension=php_interbase.dll
 extension=php_java.dll
 extension=php_ldap.dll
 extension=php_mbstring.dll
 ;extension=php_mcrypt.dll
 extension=php_mhash.dll
 extension=php_mime_magic.dll
 extension=php_ming.dll
 extension=php_mssql.dll
 extension=php_msql.dll
 ;extension=php_oci8.dll
 extension=php_openssl.dll
 ;extension=php_oracle.dll
 extension=php_pdf.dll
 extension=php_pgsql.dll
 ;extension=php_printer.dll
 extension=php_shmop.dll
 extension=php_snmp.dll
 extension=php_sockets.dll
 ;extension=php_sybase_ct.dll
 extension=php_w32api.dll
 extension=php_xmlrpc.dll
 extension=php_xslt.dll
 extension=php_yaz.dll
 extension=php_zip.dll
找到session.save_path改为session.save_path=C:\Program Files\php\tmp     \\SESSION存放路径
修改完成后,保存php.ini,到此完成PHP的安装和配置。


开始配置Apache
打开C:\Program Files\Apache Group\Apache2\conf\httpd.conf
 找到AddType application/x-tar .tgz在后面加入
  AddType application/x-httpd-php .phtml .pwml .php3 .php4 .php .php2 .inc
  AddType image/x-icon .ico
 找到#LoadModule ssl_module modules/mod_ssl.so在后面加入
  LoadModule php4_module “C:\Program Files\php\sapi\php4apache2.dll”  
找到AddDefaultCharset ISO-8859-1把它注掉      
 设置主页位置,找到DocumentRoot修改成你的叶子存放位置
 增加默认主页,找到DirectoryIndex 加入index.php index.php3 index.php4
 在DocumentRoot位置下建立一个index.php
  打开index.php输入<? phpinfo() ?>
重新启动Apache
打开127.0.0.1,如果能看到php信息,说明已经配好,Apache+php环境到此配置完成.

然后安装Tomcat
安装j2sdk-1_4_2_05-windows-i586-p.exe,默认安装
解压缩jakarta-tomcat-connectors-jk2.0.4-win32-apache2.0.49,默认安装
解压缩jakarta-tomcat-5.0.28.zip到从c:\tomcat下
配置环境变量
名:CATALINA_BASE
值:c:\tomcat
名:CATALINA_HOME
值:c:\tomcat
名:CLASSPATH
值:.;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;%CATALINA_HOME%\common\lib\servlet-api.jar;
名:JAVA_HOME
值:c:\j2sdk1.4.2_05

1,把modules\mod_jk2.so 复制到C:\Program Files\Apache Group\Apache2\modules下
2,打开C:\Program Files\Apache Group\Apache2\conf\httpd.conf找到LoadModule 在下面加入LoadModule jk2_module modules/mod_jk2.so
3,在C:\Program Files\Apache Group\Apache2\conf\新建一个workers2.properties,录入:
[shm]
file=${serverRoot}/logs/shm.file
size=1048576


# Define the communication channel
[channel.socket:localhost:8009]
#info=Ajp13 forwarding over socket
#tomcatId=localhost:8009
port=8009
host=127.0.0.1


#defint the worker
[ajp13:localhost:8009]
channel=channel.socket:localhost:8009


# Map the Tomcat examples webapp to the Web server uri space
[uri:/sky/*]
worker=ajp13:localhost:8009
#info=Map the whole webapp


4.打开C:\tomcat\conf\jk2.properties
## THIS FILE MAY BE OVERRIDEN AT RUNTIME. MAKE SURE TOMCAT IS STOPED
## WHEN YOU EDIT THE FILE.


## COMMENTS WILL BE _LOST_


## DOCUMENTATION OF THE FORMAT IN JkMain javadoc.


# Set the desired handler list
# handler.list=apr,request,channelJni
handler.list=apr,channelSocket,request
#
# Override the default port for the socketChannel
 channelSocket.port=8009
# Default:
# channelUnix.file=${jkHome}/work/jk2.socket
# Just to check if the the config  is working
# shm.file=${jkHome}/work/jk2.shm


# In order to enable jni use any channelJni directive
# channelJni.disabled = 0
# And one of the following directives:


# apr.jniModeSo=/opt/apache2/modules/mod_jk2.so


# If set to inprocess the mod_jk2 will Register natives itself
# This will enable the starting of the Tomcat from mod_jk2
# apr.jniModeSo=inprocess
然后在C:\tomcat\webapps\ROOT\下新建一个test.jsp 录入<% out.printnl(“test ok”);%>
就此配置完成
起tomcat,然后起apache
然后访问127.0.0.1/test.jsp完成

2004年10月18日

1.  确认数据库现在运行在Archive log模式下

     查看Archive备份路径

     查看是否为自动归档模式

     archive log list 

      数据库日志模式            存档模式
     自动存档             启用
     存档终点            C:\oracle\oradata\TEST\archive
     最早的概要信息日志序列     52
     下一个存档日志序列   54
     当前日志序列           54

2.  建立一个实验用表空间TEST,用户TEST,表TEST

3.  向TEST表中查入数据

     insert into test values(1);   //这样就有一条值为1的数据了。

4.  切换日志,使归档

     alter system switch logfile;    //多输入几次,以保证归档

5.  切换表空间为备份模式

     alter tablespace test begin backup;

6.  copy 表空间的数据文件

     查看数据文件:

     select file#,status,enabled,name from v$datafile;

     查看控制文件:

     select * from v$controlfile;

     查看联机日志:

     select * from v$logfile;

7.  结束TEST表空间的备份模式

     alter tablespace test end backup;

8.  继续向TEST表空插入一些数据

9.  关闭数据库,删除TEST数据文件,模拟数据库数据文件损坏。

10.  启动数据库(此时应该报错),脱机该数据文件。

        startup

        select * from v$recover_file;

        alter database datafile N offline drop;   //此处N为上一SQL查到的file值

11.  打开数据库,CP备份回来,并恢复该数据文件。

      alter database open ;

      copy 刚才备份的数据文件回来

      recover datafile N    //此处N和上面一个一样

12.  恢复成功后,联机该数据文件

       alter database datafile N online;

13.  检查数据库数据,恢复完成。

 

用法: rpm [选项...]

查询选项 (参数 -q 或 –query):
  -c, –configfiles                列出所有配置文件
  -d, –docfiles                   列出所有文档文件
  –dump                           导出基本文件信息
  -l, –list                       列出包内的所有文件
  –queryformat=QUERYFORMAT        使用紧跟的查询格式
  -s, –state                      显示文件列表的状态
  -v, –verbose                    显示详细的文件列表
  -a, –all                        查询/校验所有包
  -f, –file                       查询/校验包的包含文件
  -g, –group                      查询/校验组内的包
  -p, –package                    查询/校验一个包文件(例如一个二进制的 *.rpm 文件)
  –querytags                      显示已知的查询标签
  –specfile                       查询规格文件
  –whatrequires                   查询/校验指定包的依赖关系
  –whatprovides                   查询/校验指定包的被依赖关系

校验选项 (参数 -V 或 –verify):
  –nomd5[|=0x1]                   不使用MD5分类校验文件
  –nofiles[|=0x10000]             不校验包中的文件
  –nodeps[|=0x20000]              不校验包的依赖关系
  –noscript[|=0x40000]            不执行校验脚本(任何脚本)
  -a, –all                        查询/校验所有包
  -f, –file                       查询/校验包所含的文件
  -g, –group                      查询/校验组内的包
  -p, –package                    查询/校验一个包文件(例如一个二进制的 *.rpm 文件)
  –querytags                      显示已知的查询标签
  –specfile                       查询规格文件
  –whatrequires                   查询/校验指定包的依赖关系
  –whatprovides                   查询/校验指定包的被依赖关系

签名选项:
  –addsign                        往包内增加一个签名
  –resign                         签名一个包(去除当前签名)
  -K, –checksig                   校验包的签名
  –nogpg[&=~0x4]                  忽略任何GPG的签名
  –nomd5[&=~0x2]                  不校验文件的MD5的校验数

数据库选项:
  –initdb                         初始化数据库
  –rebuilddb                      从已安装包的头信息中重建数据库的反转列表

安装/升级/卸载选项:
  –allfiles[|=0x40]               安装所有文件, 忽略找不到的配置项里面的部分
  –allmatches[|=0x2]              卸载所有和<package>项匹配的包。(如果<package>中指定多个包则会产生一个错误信息)
  –badreloc[|=0x8]                在非重定位包中重定位文件
  -e, –erase=<package>+           卸载包
  –excludedocs[|=0x20]            不安装文档
  –excludepath=<path>             带引导组件的忽略文件<path>
  –force[|=0x74]                  –replacepkgs –replacefiles的快捷方式
  -F, –freshen=<packagefile>+     在已安装的情况下升级包
  -h, –hash[|=0x2]                为安装包打上哈希标记(最好带-v选项)
  –ignorearch[|=0x2]              不校验包的体系
  –ignoreos[|=0x1]                不校验包的操作系统
  –ignoresize[|=0x180]            安装之前不检查磁盘空间
  –includedocs                    安装文档
  –install=<packagefile>+         安装包
  –justdb[|=0x8]                  升级数据库,但是不修改文件系统
  –nodeps                         不校验包的依赖关系
  –noorder[|=0x8]                 不重新记录包的安装信息到依赖性中
  –noscripts[|=0xff0000]          不执行包的脚本
  –notriggers[|=0x990000]         不执行被该安装包触发的任何脚本
  –oldpackage[|=0x40]             升级到该包的一个旧版本
                                   (–force 升级的时候,该操作自动执行)
  –percent[|=0x1]                 打印包的安装进度
  –prefix=<dir>                   如果允许重定位,则重定位包到<dir>
  –relocate=<old>=<new>           从路径<old>到<new>重定位文件
  –repackage[|=0x400]             重新打包保存下来的卸载包的文件
  –replacefiles[|=0x30]           安装时用包文件替换已安装文件
  –replacepkgs[|=0x4]             如果包已经存在,那么重新安装
  –test[|=0x1]                    不安装包,但是要检测能否正常运行
  -U, –upgrade=<packagefile>+     升级包

所有rpm模式的通用选项:
  –version                        打印所使用的rpm的版本信息
  –quiet                          提供少量详细信息输出
  -v, –verbose                    提供更多的详细信息输出
  –define=’<name> <body>’         使用值<body>来定义宏<name>
  –eval=<expr>+                   打印<expr>+的宏扩展
  -r, –root=<dir>                 使用<dir>作为顶层目录(默认: “/”)
  –macros=<file:…>              读入<file:…>来代替默认的宏文件
  –rcfile=<file:…>              读入<file:…>来代替默认的rpmrc文件
  –showrc                         显示最终的rpmrc和macro配置

通过popt alias/exec 实现的选项:
  –scripts                        列出包中的所有安装/卸载脚本
  –setperms                       在包中设置文件的权限
  –setugids                       在包中设置文件的用户/组关系
  –conflicts                      列出此包的兼容性
  –obsoletes                      列出安装此包需要卸载的别的包
  –provides                       列出此包提供的兼容性
  –requires                       列出此包所需要的兼容性
  –info                           列出包中的叙述信息
  –changelog                      列出该包的变更日志
  –triggers                       列出包中的触发脚本
  –last                           根据安装时间列出包,最近时间的优先
  –filesbypkg                     列出每个包的所有文件
  –redhatprovides                 根据所包含的提供的兼容性查找包名(需要安装包rpmdb-redhat)
  –redhatrequires                 根据所依赖的包的兼容性查找包名(需要安装包rpmdb-redhat)
  –buildpolicy=<policy>           设置包的根目录<policy>(例如,压缩man手册)
  –with=<option>                  打开打包的<选项>配置
  –without=<option>               关闭打包的<选项>配置

帮助选项:
  -?, –help                       显示该帮助信息
  –usage                          显示用法摘要

******************************************************1.如何不安装但是获取rpm包中的文件 使用工具rpm2cpio和cpio rpm2cpio xxx.rpm | cpio -vi rpm2cpio xxx.rpm | cpio -idmv rpm2cpio xxx.rpm | cpio --extract --make-directories 参数i和extract相同,表示提取文件。v表示指示执行进程 d和make-directory相同,表示根据包中文件原来的路径建立目录 m表示保持文件的更新时间。 

2.如何查看与rpm包相关的文件和其他信息 下面所有的例子都假设使用软件包mysql-3.23.54a-11 1.我的系统中安装了那些rpm软件包 rpm -qa 讲列出所有安装过的包 如果要查找所有安装过的包含某个字符串sql的软件包 rpm -qa |grep sql 

3.如何获得某个软件包的文件全名 rpm -q mysql 可以获得系统中安装的mysql软件包全名,从中可以获得 当前软件包的版本等信息。这个例子中可以得到信息mysql-3.23.54a-11 

4.一个rpm包中的文件安装到那里去了? rpm -ql 包名 注意这里的是不包括.rpm后缀的软件包的名称 也就是说只能用mysql或者mysql-3.23.54a-11而不是mysql-3.23.54a-11.rpm。 如果只是想知道可执行程序放到那里去了,也可以用which,比如 which mysql 

5.一个rpm包中包含那些文件 一个没有安装过的软件包,使用rpm -qlp ****.rpm 一个已经安装过的软件包,还可以使用rpm -ql ****.rpm 

6.如何获取关于一个软件包的版本,用途等相关信息? 一个没有安装过的软件包,使用rpm -qip ****.rpm 一个已经安装过的软件包,还可以使用rpm -qi ****.rpm 

6.某个程序是哪个软件包安装的,或者哪个软件包包含这个程序 rpm -qf `which 程序名` 返回软件包的全名 rpm -qif `which 程序名` 返回软件包的有关信息 rpm -qlf `which 程序名` 返回软件包的文件列表 注意,这里不是引号,而是`,就是键盘左上角的那个键。 也可以使用rpm -qilf,同时输出软件包信息和文件列表 

7.某个文件是哪个软件包安装的,或者哪个软件包包含这个文件 注意,前一个问题中的方法,只适用与可执行的程序,而下面的方法,不仅可以 用于可执行程序,也可以用于普通的任何文件。前提是知道这个文件名。 首先获得这个程序的完整路径,可以用whereis或者which,然后使用rpm -qf例如: # whereis ftptop ftptop: /usr/bin/ftptop /usr/share/man/man1/ftptop.1.gz # rpm -qf /usr/bin/ftptop proftpd-1.2.8-1 # rpm -qf /usr/share/doc/proftpd-1.2.8/rfc/rfc0959.txt proftpd-1.2.8-1 

总结: 获得软件包相关的信息用rpm -q,q表示查询query,后面可以跟其他选项,比如 i 表示info,获得软件包的信息; l 表示list,获得文件列表; a 表示all,在所有包中执行查询; f 表示file,根据文件进行相关的查询; p 表示package,根据软件包进行查询 需要的查询条件可以使用grep产生,或者从"` `"中的命令行产生 

7.关于rpm软件包的一些相关知识 1.什么是rpm rpm 即RedHat Package Management,是RedHat的发明之一 

8.为什么需要rpm 在一个操作系统下,需要安装实现各种功能的软件包。这些软件包一般都有各自的 程序,但是同时也有错综复杂的依赖关系。同时还需要解决软件包的版本,以及安装, 配置,卸载的自动化问题。为了解决这些问题,RedHat针对自己的系统提出了一个 较好的办法来管理成千上百的软件。这就是RPM管理系统。在系统中安装了rpm管理系统 以后,只要是符合rpm文件标准的打包的程序都可以方便的安装,升级,卸载 

9.是不是所有的linux都使用rpm 任何系统都需要包管理系统,因此很多linux都使用rpm系统。但rpm系统是为RH专门 但是TL,Mandrake等系统也都使用rpm。由于rpm的源程序可以在别的系统上进行编译, 所以有可能在别的系统上也使用rpm 除了rpm,其他一些系统也有自己的软件包管理程序,例如debian的deb包, slakware也都有自己的包管理系统 

10.rpm包的文件名为什么那么长 rpm包的文件名中包含了这个软件包的版本信息,操作系统信息,硬件要求等等。 比如mypackage-1.1-2TL.i386.rpm,其中mypackage是在系统中登记的软件包的名字 1.1是软件的版本号,2是发行号,TL表示用于TL操作系统,还可能是RH等。i386表示 用于intel x86平台,还可能是sparc等。 

11.软件包文件名中的i386,i686是什么意思 rpm软件包的文件名中,不仅包含了软件名称,版本信息,还包括了适用的硬件架构 的信息。 i386指这个软件包适用于intel 80386以上的x86架构的计算机(AI32) i686指这个软件包适用于intel 80686以上(奔腾pro以上)的x86架构的计算机(IA32) noarch指这个软件包于硬件架构无关,可以通用。 i686软件包的程序通常针对CPU进行了优化,所以,向后兼容比较用以,i386的包在 x86机器上都可以用。向前一般不兼容。不过现在的计算机,奔腾pro以下的CPU已经很少 用,通常配置的机器都可以使用i686软件包 

12.不同操作系统发行的rpm包可否混用? 对于已经编译成二进制的rpm包,由于操作系统环境不同,一般不能混用。 对于以src.rpm发行的软件包,由于需要安装时进行本地编译,所以通常可以在不同 系统下安装。 

13.使用rpm时遇到的一些特殊问题 Q 我用rpm -e **.rpm无法删除rpm包 A 包名不要包括rpm, rpm -e 包名,可以包含版本号等信息,但是不可以有后缀.rpm 

Q 在MS的系统下有没有读RPM文件的工具? A wincmd with rpm plugins..... 

Q 是否可以通过ftp安装安装升级rpm包? A 可以。rpm -ivh ftp://xxxxxxxx/PATH2SomeRPM 

Q rpm安装时已有的包版本过高怎么办? A 有时由于安装的软件包太老,而系统中相关的软件包版本比较新,所以可能需要 安装的包依赖的一些文件会找不到。这时有两种解决办法, 第一是在系统文件中找到和需要的文件功能相同或相似的文件,做一个符号链接到 需要的目录下。 第二是下载安装新版本的软件包。

[b:7639f4d5ed]进入vi的命令[/b:7639f4d5ed]
vi  filename   :打开或新建文件,并将光标置于第一行首
vi  +n filename  :打开文件,并将光标置于第n行首
vi  + filename    :打开文件,并将光标置于最后一行首
vi +/pattern filename:打开文件,并将光标置于第一个与pattern匹配的串处
vi  -r filename :在上次正用vi编辑时发生系统崩溃,恢复filename
vi  filename….filename :打开多个文件,依次进行编辑

[b:7639f4d5ed]移动光标类命令[/b:7639f4d5ed][/b]
h :光标左移一个字符
l  :光标右移一个字符
space:光标右移一个字符
Backspace:光标左移一个字符
k或Ctrl+p:光标上移一行
j或Ctrl+n :光标下移一行
Enter :光标下移一行
w或W :光标右移一个字至字首
b或B :光标左移一个字至字首
e或E :光标右移一个字至字尾
) :光标移至句尾
( :光标移至句首
}:光标移至段落开头
{:光标移至段落结尾
nG:光标移至第n行首
n+:光标下移n行
n-:光标上移n行
n$:光标移至第n行尾
H :光标移至屏幕顶行
M :光标移至屏幕中间行
L :光标移至屏幕最后行
0:(注意是数字零)光标移至当前行首
$:光标移至当前行尾

[b:7639f4d5ed]屏幕翻滚类命令[/b:7639f4d5ed]
Ctrl+u:向文件首翻半屏
Ctrl+d:向文件尾翻半屏
Ctrl+f:向文件尾翻一屏
Ctrl+b;向文件首翻一屏
nz:将第n行滚至屏幕顶部,不指定n时将当前行滚至屏幕顶部。

[b:7639f4d5ed]插入文本类命令[/b:7639f4d5ed]
i :在光标前
I :在当前行首
a:光标后
A:在当前行尾
o:在当前行之下新开一行
O:在当前行之上新开一行
r:替换当前字符
R:替换当前字符及其后的字符,直至按ESC键
s:从当前光标位置处开始,以输入的文本替代指定数目的字符
S:删除指定数目的行,并以所输入文本代替之
ncw或nCW:修改指定数目的字
nCC:修改指定数目的行

[b:7639f4d5ed]删除命令[/b:7639f4d5ed]
ndw或ndW:删除光标处开始及其后的n-1个字
do:删至行首
d$:删至行尾
ndd:删除当前行及其后n-1行
x或X:删除一个字符,x删除光标后的,而X删除光标前的
Ctrl+u:删除输入方式下所输入的文本

[b:7639f4d5ed]搜索及替换命令[/b:7639f4d5ed]
/pattern:从光标开始处向文件尾搜索pattern
?pattern:从光标开始处向文件首搜索pattern
n:在同一方向重复上一次搜索命令
N:在反方向上重复上一次搜索命令
:s/p1/p2/g:将当前行中所有p1均用p2替代
:n1,n2s/p1/p2/g:将第n1至n2行中所有p1均用p2替代
:g/p1/s//p2/g:将文件中所有p1均用p2替换

[b:7639f4d5ed]选项设置[/b:7639f4d5ed]
all:列出所有选项设置情况
term:设置终端类型
ignorance:在搜索中忽略大小写
list:显示制表位(Ctrl+I)和行尾标志($)
number:显示行号
report:显示由面向行的命令修改过的数目
terse:显示简短的警告信息
warn:在转到别的文件时若没保存当前文件则显示NO write信息
nomagic:允许在搜索模式中,使用前面不带“\”的特殊字符
nowrapscan:禁止vi在搜索到达文件两端时,又从另一端开始
mesg:允许vi显示其他用户用write写到自己终端上的信息

[b:7639f4d5ed]最后行方式命令[/b:7639f4d5ed]
:n1,n2 co n3:将n1行到n2行之间的内容拷贝到第n3行下
:n1,n2 m n3:将n1行到n2行之间的内容移至到第n3行下
:n1,n2 d :将n1行到n2行之间的内容删除
:w :保存当前文件
:e filename:打开文件filename进行编辑
:x:保存当前文件并退出
:q:退出vi
:q!:不保存文件并退出vi
:!command:执行shell命令command
:n1,n2 w!command:将文件中n1行至n2行的内容作为command的输入并执行之,若不指定n1,n2,则表示将整个文件内容作为command的输入
:r!command:将命令command的输出结果放到当前行

[b:7639f4d5ed]寄存器操作[/b:7639f4d5ed]
“?nyy:将当前行及其下n行的内容保存到寄存器?中,其中?为一个字母,n为一个数字
“?nyw:将当前行及其下n个字保存到寄存器?中,其中?为一个字母,n为一个数字
“?nyl:将当前行及其下n个字符保存到寄存器?中,其中?为一个字母,n为一个数字
“?p:取出寄存器?中的内容并将其放到光标位置处。这里?可以是一个字母,也可以是一个数字
ndd:将当前行及其下共n行文本删除,并将所删内容放到1号删除寄存器中。
********************************************
vi 高级技巧

交换两个字符位置
xp
上下两行调换
ddp
把文件内容反转
:g/^/m0/
保存后就加密
:X
上下两行合并 
J
删除所有行 
dG
从当前位置删除到行尾
d$
从当前位置复制到行尾
y$ 如果要粘贴到其他地方 p 就可以了

在命令状态下,nyy表示拷贝从光标行起的下n行内容,p表示paste,粘贴下来在光标处。
我常用到的单个字符替换用r,覆盖多个字符用R,用多个字符替换一个字符用s,整行替换用S
:%s/old_word/new_word/g
这个指令是于在整个文件中替换特定字符串
将光标移到第n行,按下 mk
将光标移到第m行,按下 ”ay’k
即将第n到m的行存到a寄存器,以此类推,b,c……..寄存器等
删除命令操作
d l 删除当前字符(与x命令功能相同)
d 0 删除到某一行的开始位置
d ^ 删除到某一行的第一个字符位置(不包括空格或TA B字符)
d w 删除到某个单词的结尾位置
d 3 w 删除到第三个单词的结尾位置
d b 删除到某个单词的开始位置
d W 删除到某个以空格作为分隔符的单词的结尾位置
d B 删除到某个以空格作为分隔符的单词的开始位置
下载
(续)
删除命令操作
d 7 B 删除到前面7个以空格作为分隔符的单词的开始位置
d) 删除到某个语句的结尾位置
d 4) 删除到第四个语句的结尾位置
d( 删除到某个语句的开始位置
d } 删除到某个段落的结尾位置
d { 删除到某个段落的开始位置
d 7 { 删除到当前段落起始位置之前的第7个段落位置
d d 删除当前行
d /t e x t 删除从文本中出现“ t e x t”中所指定字样的位置,一直向前直到下一个该字样所出现的
位置(但不包括该字样)之间的内容
d fc 删除从文本中出现字符“c”的位置,一直向前直到下一个该字符所出现的位置(包括
该字符)之间的内容
d tc 删除当前行直到下一个字符“ c”所出现位置之间的内容
D 删除到某一行的结尾
d $ 删除到某一行的结尾
5 d d 删除从当前行所开始的5行内容
d L 删除直到屏幕上最后一行的内容
d H 删除直到屏幕上第一行的内容
d G 删除直到工作缓存区结尾的内容
d 1 G 删除直到工作缓存区开始的内容
下载

表8-3 修改命令
修改命令操作
c l 更改当前字符
c w 修改到某个单词的结尾位置
c 3 w 修改到第三个单词的结尾位置
c b 修改到某个单词的开始位置
c W 修改到某个以空格作为分隔符的单词的结尾位置
c B 修改到某个以空格作为分隔符的单词的开始位置
c 7 B 修改到前面7个以空格作为分隔符的单词的开始位置
c 0 修改到某行的结尾位置
c) 修改到某个语句的结尾位置
c 4) 修改到第四个语句的结尾位置
c( 修改到某个语句的开始位置
c } 修改到某个段落的结尾位置
c { 修改到某个段落的开始位置
c 7 { 修改到当前段落起始位置之前的第7个段落位置
c tc 修改当前行直到下一个字符c所出现位置之间的内容
C 修改到某一行的结尾
c c 修改当前行
5 c c 修改从当前行所开始的5行内容

表8-4 替换命令
替换命令操作
s 将当前字符替换为一个或多个字符
S 将当前行替换为一个或多个字符
5 s 将从当前字符开始的5个字符替换为一个或多个字符
fx
往右移动到 x 字符上
Fx
往左移动到 x 字符上
tx
往右移动到 x 字符前
Tx
往左移动到 x 字符后
(注意:以上四个命令中,其中x是键入的字符)
;
分号,配合 f 和 t 使用,重复一次 
,
逗号,配合 f 和 t 使用,反方向重复一次
追加到缓冲区
对于已经有内容的缓冲区,可以继续追加内容在其后面,例如:
“Ad4w      删除光标后4个字,并附加到缓冲区a
“Ay)       取样从光标到文件尾的内容,并附加到缓冲区a
“K3yy      取样从光标所在行起的3行内容,并附加到缓冲区k
删除从当前行开始到最后一行的所有内容
:.,$d
在:命令行模式下,首先可以确定命令的范围
.表示当前行;数字表示行号,如1表示第一行,2表示第二行;$表示最后一行
范围用,分隔
然后用命令
d表示删除,y表示复制……大家都知道的

最后说一句,%表示全文
:%d
是删除全文