Nob經常使用命令

說明:此文件爲經常使用的命令筆記
規則:  
1、使用"[組名]"分組,如[linux]
2、使用"<標題一>"標示知識點,可用"<<二級>>",類推"<<<三級>>>"
3、關鍵詞以字典序排列
4、linux相關放置最末尾

[超級經常使用命令]
netstat -tunpl | grep 3128        #查看是否開啓3128端口            
pstree -p |grep mongod                  #查看進程

sudo ./redis-server /data/server/redis/etc/redis.conf
sudo ./mongod --dbpath=/data/server/mongodb/data/ --logpath=/data/server/mongodb/dblogs --fork
<redis>
keys *        #查看全部的key

<mongo>
show dbs  #查看全部的數據庫



{"author": "Mike","text": "My first blog post!", "tags": ["mongodb", "python", "pymongo"],"date": datetime.datetime.utcnow()}

[nob-note]
<squid代理服務器>
同一個網段裏的兩臺設備通訊不須要網關。

[快速查找,熟悉後歸類到對於目錄]
<vim塊註釋>
#用v進入virtual模式
#用上下鍵選中須要註釋的行數

1.插入註釋:
按Control+v進入列模式
按大些「I」進入插入模式,輸入註釋符「#」,而後馬上按下ESC

2.刪除註釋
先按Control+v進入列模式
選中要刪除的註釋符,而後按d ,進行刪除


[cmd]
#自動關機,電腦就會在18:00自動關機,注意:-s是控制符,不能缺省。 
at 18:00 shutdown -s
#取消自動關機,在運行中輸入「shutdown -a」。另外輸入「shutdown -i」,則能夠打開設置自動關機對話框,對自動關機進行設置。 

<cmd-linux風格>
#給windows添加ls命令
#C:\windows目錄下新建一個文件 命名爲 ls.bat,輸入: 
    @echo off 
    dir

<h4>利用筆記本自帶網卡搭建虛擬wifi</h4>
#啓用虛擬網卡,設置wifi的ssid和密碼
netsh wlan set hostednetwork mode=allow ssid=nob key=12345678
netsh wlan start hostednetwork

#DNS刷新
ipconfig /flushdns

#回車後出現一塊虛擬無限網卡,將已鏈接到網絡的網卡共享給虛擬無線網卡
#啓動wifi基站
netsh wlan start hostednetwork
#回車後虛擬無限網卡紅叉消失,一切ok

tracert 183.94.94.71
<服務管理>
#在cmd下可有兩種方法打開,net和sc,net用於打開沒有被禁用的服務,語法是:
net start 服務名
net stop 服務名

用sc可打開被禁用的服務,語法是:
sc config 服務名 start= demand            #手動
sc condig 服務名 start= auto              #自動
sc config 服務名 start= disabled         #禁用
sc start 服務名
sc stop   服務名

[git]
如今git上創建工程
git clone git@git.oschina.net:nob/yiqiwanshua.git #注意git@oschina使用https好像有問題

新增或改動文件
git add * #添加
git commit -m "nob commit"#提交

刪除文件
git rm file1
git commit -m "del file1"

git push origin master #推送到遠程


[httpd]
<ubuntu下安裝>
sudo apt-get install apache2
sudo /etc/init.d/apache2 restart

[java]
#CentOS-6.3安裝配置JDK-7
    http://www.cnblogs.com/zhoulf/archive/2013/02/04/2891608.html

[maven]
<常見mvn命令>
 
mvn compile                        #編譯源代碼:
mvn package                        #打包
java -jar target/xxx-0.1.0.jar    #運行打包生成的jar
mvn install                        # install your project’s JAR file to that local repository
mvn site                        #生成site


#maven倉庫配置,oschina示例
    http://maven.oschina.net/help.html
#建立一個簡單的maven示例
mvn archetype:create -DgroupId=oschina -DartifactId=simple -DpackageName=net.oschina.simple  -DarchetypeArtifactId=maven-archetype-webapp -DinteractiveMode=false

#查看maven系統配置
mvn help:system

[mysql]
yum install mysql mysql-server mysql-devel
<數據導出導入>
導出:mysqldump -u 用戶名 -p 數據庫名 > 導出的文件名 
如:mysqldump -u root -p voice>voice.sql

導入:
\. d:/test.sql 或 souce d:/test.sql 

<新建表>
CREATE TABLE `user` (
`id`  int(8) NOT NULL AUTO_INCREMENT ,
`username`  varchar(16) NOT NULL ,
`password`  varchar(16) NOT NULL ,
PRIMARY KEY (`id`)
)
ENGINE=InnoDB
;

<<安裝配置>>
#安裝無需多說,yum快速安裝
1、安裝
查看有沒有安裝過:
    yum list installed mysql*
    rpm -qa | grep mysql*
 
查看有沒有安裝包:
    yum list mysql*
 
 
安裝mysql客戶端:
    yum install mysql
 
安裝mysql 服務器端:
    yum install mysql-server
    yum install mysql-devel
    
2、啓動&&中止
 數據庫字符集設置
    mysql配置文件/etc/my.cnf中加入default-character-set=utf8
 
啓動mysql服務:
    service mysqld start或者/etc/init.d/mysqld start
開機啓動:
    chkconfig -add mysqld,查看開機啓動設置是否成功chkconfig --list | grep mysql*
    mysqld             0:關閉    1:關閉    2:啓用    3:啓用    4:啓用    5:啓用    6:關閉
中止:
    service mysqld stop
2、登陸
建立root管理員:
    mysqladmin -u root password 123456
  
登陸:
    mysql -u root -p輸入密碼便可。
忘記密碼:
    service mysqld stop
    mysqld_safe --user=root --skip-grant-tables
    mysql -u root
    use mysql
    update user set password=password("new_pass") where user="root";
    flush privileges;  
 
3、遠程訪問
 開放防火牆的端口號
mysql增長權限:mysql庫中的user表新增一條記錄host爲「%」,user爲「root」。

4、Linux MySQL的幾個重要目錄
數據庫目錄
    /var/lib/mysql/
配置文件
    /usr/share /mysql(mysql.server命令及配置文件)
相關命令
    /usr/bin(mysqladmin mysqldump等命令)
啓動腳本
    /etc/rc.d/init.d/(啓動腳本文件mysql的目錄)
         
service mysqld start            #初次啓動mysqld會進行初始化,其中下面內容尤爲注意:

/usr/bin/mysqladmin -u root password 'new-password'
/usr/bin/mysqladmin -u root -h localhost.centos password 'new-password'
#以上指令在初始化的時候建立了帳號root的密碼,因此可用以上帳號修改密碼
/usr/bin/mysqladmin -u root password 'root'        #設置root的密碼爲root

<<字符集設置>>
#查看編碼
show variables like 'collation_%';
show variables like 'character_set_%';
vi /etc/my.cnf
#在[client]下添加
default-character-set=utf8
#在[mysqld]下添加
default-character-set=utf8

<<建立mysql用戶>>

#update方式管理用戶
use mysql;
select Host,User,Password from user;                #查看可登陸的mysql用戶
update user set Host='%' where Host='localhost';    #把Host='localhost'的用戶Host改成%,這樣不會限制登陸ip
flush privileges;                                    #刷新更改

#grant方式建立,INSERT也可建立用戶 
#建立新帳號monty,密碼爲some_pass,本地帳號
mysql> GRANT ALL PRIVILEGES ON *.* TO 'monty'@'localhost'
    ->     IDENTIFIED BY 'some_pass' WITH GRANT OPTION;
#建立新帳號monty,密碼爲some_pass,鏈接主機爲%,可從任何主機鏈接
mysql> GRANT ALL PRIVILEGES ON *.* TO 'monty'@'%'
    ->     IDENTIFIED BY 'some_pass' WITH GRANT OPTION;

<<建立數據庫>>
GBK: create database test2 DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;

UTF8: CREATE DATABASE `test2` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;


[php]

<apache+php+mysql>
<<安裝apache>>
cd httpd-2_x_NN
./configure --enable-so
make
make install

<<安裝php>>
cd ../php-NN
./configure --with-apxs2=/usr/local/apache2/bin/apxs --with-mysql
make
make install
#配置php.ini
cp php.ini-development /usr/local/lib/php.ini

#編輯 httpd.conf 文件以調用 PHP 模塊。
#LoadModule 表達式右邊的路徑必須指向系統中的PHP.以上make install命令可能已經完成了這些但務必要檢查
#LoadModule php5_module modules/libphp5.so

#告知 Apache 將特定的擴展名解析成 PHP,例如,讓 Apache 將擴展名 .php 解析成 PHP。
    <FilesMatch \.php$>
        SetHandler application/x-httpd-php
    </FilesMatch>

#而後,能夠將 .phps 文件由 PHP 源碼過濾器處理,使得其在顯示時能夠高亮源碼,設置以下: 
    <FilesMatch "\.phps$">
        SetHandler application/x-httpd-php-source
    </FilesMatch>

#mod_rewrite 也有助於將那些不須要運行的 .php 文件的源碼高亮顯示,而並不須要將他們改名爲 .phps 文件: 
    RewriteEngine On
    RewriteRule (.*\.php)s$ $1 [H=application/x-httpd-php-source]


[python]
#安裝依賴和導出依賴文件
(ENV)$ pip install Flask Flask-Cache Flask-SQLAlchemy
(ENV)$ pip freeze > requirements.txt

pip freeze > requirements.txt                        #將包依賴信息保存在requirements.txt文件
pip install -r requirements.txt                        #根據依賴文件安裝依賴
pip install -d /path/to/save/ -r requirements.txt    #根據依賴文件下載依賴包

#建立虛擬獨立的python環境
$ cd flask
$ virtualenv env
$ . env/bin/activate

virtualenv --system-site-packages
source env1/bin/activate



#發送get請求,hello word級別
>>> print urllib2.urlopen('http://tpai.qq.com/race/mobilecreative2014/work/19685').read()

#快速構建一個服務器,先切換到指定目錄
python -m SimpleHTTPServer 8999

#django shell交互模式導入template前導入settings
>>> from django.conf import settings
>>> settings.configure() 

#python時間戳和datetime轉換
datetime.fromtimestamp(timestamp)                    #時間戳轉換爲datetime
time.mktime(datetime.datetime.now().timetuple())    #datetime轉換爲時間戳,注意time是time模塊而非datetime中的time

<pip>
#下載安裝
curl -O https://raw.github.com/pypa/pip/master/contrib/get-pip.py
python get-pip.py
#不能聯網可到這裏下載:http://pypi.python.org/pypi/pip#downloads

#pip基本操做
pip install simplejson                        #安裝python包
pip install --upgrade simplejson            #升級python包
pip uninstall simplejson                    #卸載python包


pip install Markdown                #安裝package
pip freeze                            #列出安裝的packages

#安裝特定版本的package,經過使用==, >=, <=, >, <來指定一個版本號。
pip install 'Markdown<2.0'
pip install 'Markdown>2.0,<2.0.3'
pip install -U Markdown                升級包,升級包到當前最新的版本,可使用-U 或者 --upgrade
pip uninstall Markdown                #卸載包
pip search "Markdown"                #查詢包

<python模塊文檔>
sudo pip install sphinx
cd flask-admin
sudo make html

<安裝mod_python>
tar -zxvf mod_python-3.5.0.tgz
cd mod_python-3.5.0
./configure --with-apxs=/usr/sbin/apxs         #配置apxs目錄,若是是本身安裝的apache一般在/usr/local/apache/bin/apxs

<安裝mod_wsgi>
使用centos光盤中mod_wsgi.rpm包
    LoadModule wsgi_module modules/mod_wsgi.so

<部署一個web.py項目>
#在httpd.conf中配置Apache 加載 mod_wsgi模塊和您的項目:
      LoadModule wsgi_module modules/mod_wsgi.so

      WSGIScriptAlias /appname /var/www/webpy-app/code.py/
      Alias /appname/static /var/www/webpy-app/static/
      AddType text/html .py

      <Directory /var/www/webpy-app/>
          Order deny,allow
          Allow from all
      </Directory>
      
#演示文件 'code.py':
      import web

      urls = (
          '/.*', 'hello',
          )

      class hello:
          def GET(self):
              return "Hello, world."

      application = web.application(urls, globals()).wsgifunc()
#在您的瀏覽器地址欄中輸入' http://your_server_name/appname' 來驗證它是否可用。      

#若是您須要在mod_wsgi中使用sessions,您能夠改變您的代碼以下:
    app = web.application(urls, globals())

    curdir = os.path.dirname(__file__)
    session = web.session.Session(app, web.session.DiskStore(curdir + '/' + 'sessions'),)

    application = app.wsgifunc()

[redis]

./redis-server /data/server/redis/etc/redis.conf    #啓動redis服務
#注意,默認複製過去的redis.conf文件的daemonize參數爲no,因此redis不會在後臺運行,這時要測試,咱們須要從新開一個終端。修改成yes則爲後臺運行redis。
./redis-cli 
netstat -tunpl | grep 6379    #查看當前redis進程
      
[other]
#在微信中用html語言跳轉到指定微信的用戶關注頁面
<a href="weixin://addfriend/lzjtuxzs">點擊關注</a>

[sublime]
ctrl+shift+d        #複製行
ctrl+shift+↑↓        #移動行
ctrl+shift+p        #命令定位
ctrl+l                #選擇整行
ctrl+KU                #改成大寫
ctrl+KL                #改成小寫
alt+.                #自動完成tag
ctrl+d                #高亮當前全部詞
ctrl+shift+r        #格式化

==========================================================================================================================
[linux]
<linux常識>
綠色表明可執行文件
深藍色是目錄
淺藍色是連接
用戶軟件默認安裝目錄/usr/local/
應用程序文檔目錄/usr/share/doc/
如BIND的文檔文件夾爲/usr/share/doc/bind-9.8.2
linux命令的參數前加一個"-"是參數簡寫形式,參數前加兩個"-"的參數單詞一般完整


<未知命令>
getenforce
setenforce 0        #關閉掉

<基本操做>
cp -rv /path1/* /path2/xxx        #複製/path1/下的全部文件到/path2/xxx,-rv顯示覆制過程
rsync -a dirname /path/            #拷貝文件
ls -l | wc -l                    #查看當前的目錄下文件的個數
tar xzf filename.tgz            #解壓
grep 'dmtsai' /etc/passwd        #在文件中查找
rpm -q httpd                    #查看軟件是否安裝
chomd -R 755 dirname            #將dirname文件夾下的全部文件遞歸的改成可執行
ps -ef|grep httpd                #查看啓動的進程
df –h                            #查看硬盤
fdisk -l                        #查看分區,df -l沒法查看未分區和格式化的磁盤
<安裝後的一些配置>
#原窗口打開文件夾
1.打開一個文件夾
2.編輯 - 首選項 - 行爲,勾選「老是在瀏覽器窗口打開」,點擊關閉。

#修改CentOS的默認啓動項爲文本模式
vi /etc/inittab
修改 id:5:initdefault中的5爲3



#修改主機名
hostname nobsu
vim /etc/sysconfig/network        #修改hostname
vim /etc/hosts文件                #添加hosts

#修改日期: 
#時間設定成2009年5月10日的命令以下: 
date -s 05/10/2009 
date  -s  10:12:13

#設置網卡ip
vim /etc/sysconfig/network-scripts/ifcfg-eth0

<linux命令獲取幫助>
#使用-h或--help參數,如:
ls -help                        #查看ls命令的幫助
#使用man(manual簡寫)命令
#man [相關命令],如:
man tar                            #查看tar的手冊
#man -k keyword,查詢包含keyword的man文檔,如:
man -k password
#info命令,info提供了比man更爲詳細的文檔,用法相似man
info ls
#info和man均可以經過"/+關鍵字"進行文檔內搜索
#help,man,info,都不行能夠到/usr/share/doc/下查看軟件自己提供的文檔
#終極辦法:please use google search

grep keyword                    #過濾只顯示含有keyword的內容,可加到顯示結果爲list的命令後
chkconfig --list | grep sshd    #查看sshd服務開機啓動狀況

<帳號管理>
#每個檔案都會有所謂癿擁有者UID 不擁有羣組GID ,弼咱們有要顯示文件屬性癿需求時,系統會依據/etc/passwd和/etc/group中內容, 找到 UID / GID對應癿帳號不組名再顯示出來!
grep 'nob' /etc/passwd            #查找名爲nob的用戶

#passwd中每一行表明一個帳戶,有其部分組成使用:分割
    如:root:x:0:0:root:/root:/bin/bash


<運行級別>
cd /etc/rc.d/        #此目錄下保存的是7linux個運行級別
runleverl            #查看當前運行級別

cd /etc/rc.d/rc.5d/
ll                        #列出第五的運行級別下的服務,以下:
#都是一些連接,連接名三部分組成,K|S+數字+服務名,K表明開機不啓動,S表明開機啓動,數字表明啓動順序,服務名和實際的Sys V腳本名相同
    lrwxrwxrwx. 1 root root 16 Feb  4 17:41 K01smartd -> ../init.d/smartd
    lrwxrwxrwx. 1 root root 15 Feb  4 17:34 K15httpd -> ../init.d/httpd
    lrwxrwxrwx. 1 root root 13 Feb  4 17:35 K60nfs -> ../init.d/nfs
    ...
    lrwxrwxrwx. 1 root root 18 Feb  4 17:33 S08iptables -> ../init.d/iptables
    lrwxrwxrwx. 1 root root 17 Feb  4 17:33 S10network -> ../init.d/network
    lrwxrwxrwx. 1 root root 17 Feb  4 17:34 S12rsyslog -> ../init.d/rsyslog

<linux服務>
#命令service能夠用來調用指定服務的System V腳本,並執行指定動做
service 服務名 [start|stop|restart|status]
ps:全部的System V腳本保存在/etc/rc.d/init.d/目錄下

#命令chkconfig用來指定服務的啓用,啓用是指開機是否啓動
chkconfig 服務名 [on|off]        #設置服務開機啓動|不啓動
chkconfig --list                #列出全部服務查看開機啓動狀態

#查看全部服務狀態
service --status-all

#把apache加入到系統服務中
cp /usr/local/apache/bin/apachectl /etc/rc.d/init.d/httpd
#修改httpd,在文件頭部加入以下內容:
    ###
    # Comments to support chkconfig on RedHat Linux
    # chkconfig: 2345 90 90
    # description:http server
    ###
chkconfig --add httpd
chkconfig --level 345 httpd on

#xinetd管理的服務
#xinetd自身是一個Sys V服務,xinetd服務是一些不經常使用的、功能簡單的服務,
#xinetd相似於一個代理負責監聽對這類服務的調用,xinetd服務也經過chkconfig啓用



<dns服務>
<<dig域名解析查詢>>
dig +trace www.nobsu.net         #追蹤指定域名DNS解析過程
dig -t mx gmail.com                #查詢指定域名的mx記錄,郵件解析
dig -x www.linuxcast.net        #逆向解析,從domain到ip的解析
dig -t soa linuxcast.net         #查詢soa配置,soa是dns的zone文件中對同步時間的配置

<<安裝dns服務器軟件BIND>>
#安裝dns服務器軟件BIND,BIND服務名稱爲named
yum install -y bind bind-chroot bind-utils 
#DNS默認使用UDP、TCP協議,使用端口號爲53(domain),953(mdc)
#bind-chroot是linux的一種僞目錄機制,出於安全考慮對真實配置文件目錄改變
#bind-utils是一些工具,如檢測配置文件語法錯誤:


<<BIND配置文件>>
#BIND配置文件目錄
/etc/named.conf            #BIND服務主配置文件
/var/named/domain.zone                #zone文件
#若是安裝了bind-chroot,BIND會被封裝到一個僞根目錄,配置文件位置變爲:
/var/named/chroot/etc/named/conf    #/var/named/chroot/爲僞根

#拷貝配置文件模板
cp -rv /usr/share/doc/bind-9.8.2/sample/etc/* /var/named/chroot/etc/
cp -rv /usr/share/doc/bind-9.8.2/sample/var/* /var/named/chroot/var/
#v參數顯示拷貝過程

#主配置文件named.conf的最精簡配置以下:
    options{
            directory "var/named";                //指定工做目錄
            listion-on port 53 {127.0.0.1; };    //監聽端口,若是此dns對外服務,必須刪掉這行,或指定外網ip
            
    }
<<域主服務器配置>>
①在bind的主配置文件中添加該域的定義
#在named.conf中添加一行域的zone定義:
    zone "nobsu.net"{
        type master;
        file "nobsu.net.zone";
    },
③在/var/named/chroot/var/named中建立該域的zone文件
#拷貝模板建立nobsu.net.zone文件
cp named.localhost nobsu.net.zone
⑤編輯zone文件,添加須要的信息
#添加以下資源記錄(RR)
            IN MX 10        mail.nobsu.net.
    www        IN A    192.168.75.131
    mail    IN A    192.168.75.222
⑦啓動bind服務或使bind刷新配置
getenforce            #查看selinux配置
    Enforcing        #狀態爲Enforcing
setenforce 0        #爲了方便先關掉,設置爲Permissive狀態

service named [start|reload]    #啓動bing服務或刷新配置

⑨使用host或dig命令檢測域信息是否正常
#將本機的dns配置指向本機:
vim /etc/resolv.conf
    nameserver    127.0.0.1        #就用剛纔在本機配置的dns服務器做爲本機的dns,作測試

host www.nobsu.net
#dig www.nobsu.net    
#檢測結果以下:    
    [root@localhost etc]# host www.nobsu.net
    www.nobsu.net has address 192.168.75.1
    [root@localhost etc]# host mail.nobsu.net
    mail.nobsu.net has address 192.168.75.222    
    歐燕!!!
    
<<配置文件檢測>>
named-checkconf /var/named/chroot/etc/named.conf
named-checkzone    nobsu.net nobsu.net.zone

<httpd>
<<配置文件>>
/etc/httpd/conf/httpd.conf            #apache配置文件路徑
/etc/httpd/conf.d/                    #模塊配置文件保存路徑
/var/log/httpd/                        #默認網站日誌目錄
<<apache配置文件語法檢查>>
#service httpd configtest            #如下三種相同
#apachectl configtest
httpd -t

<<日誌>>
cd /var/log/httpd/                    #日誌目錄
    access_log  error_log           #訪問日誌和錯誤日誌
tail access_log                     #查看最近日誌記錄

<<配置虛擬主機>>
#基於域名的虛擬主機。ssl虛擬主機必須使用基於ip的方式
#首先確認DNS服務器將不一樣的域名解析到同一個ip,使用host或dig肯定解析正常
host www1.nobsu.net
host www2.nobsu.net

#在apache配置文件httpd.conf中添加:
    NameVirtualHost *:80
    <VirtualHost *:80>
        ServerName www1.nobsu.net
        ServerAdmin root@nobsu.net
        DocumentRoot /var/www/www1
    </VirtualHost>
    <VirtualHost *:80>
        ServerName www2.nobsu.net
        ServerAdmin root@nobsu.net
        DocumentRoot /var/www/www2
    </VirtualHost>

#建立app的文件目錄
cd /var/www/
mkdir www1
mkdir www2
chown apache www*        #修改這兩個目錄的所屬用戶爲apache    
#重啓httpd服務,OK

<mysqld>
#linux下使用yum安裝mysql,以及啓動、登陸和遠程訪問。
#一、安裝
yum list installed mysql*                #查看有沒有安裝過:
rpm -qa | grep mysql*
yum list mysql*                            #查看有沒有安裝包:
yum install mysql                        #安裝mysql客戶端:
yum install mysql-server                #安裝mysql 服務器端:
yum install mysql-devel

#二、啓動&&中止
#數據庫字符集設置
    mysql配置文件/etc/my.cnf中加入default-character-set=utf8

service mysqld start或者/etc/init.d/mysqld start        #啓動mysql服務:
chkconfig -add mysqld                                    #開機啓動:
chkconfig --list | grep mysql*                            #查看開機啓動設置是否成功

#三、登陸
mysqladmin -u root password 123456                        #建立root管理員:
mysql -u root -p輸入密碼便可。                            #登陸:

#忘記密碼:
service mysqld stop
mysqld_safe --user=root --skip-grant-tables
mysql -u root
use mysql
update user set password=password("new_pass") where user="root";
flush privileges;  

#四、遠程訪問
#開放防火牆的端口號
#mysql增長權限:
    mysql庫中的user表新增一條記錄host爲「%」,user爲「root」。

#五、Linux MySQL的幾個重要目錄
#數據庫目錄
    /var/lib/mysql/
#配置文件
    /usr/share /mysql(mysql.server命令及配置文件)
相關命令
    /usr/bin(mysqladmin mysqldump等命令)
啓動腳本
    /etc/rc.d/init.d/(啓動腳本文件mysql的目錄)     

<vim命令>
#命令模式:vim啓動進入命令模式,任何模式按esc進入
i        #在光標前插入文本
o        #在當前行下面插入新行
dd        #刪除整行
yy        #複製當前行
n+yy    #複製n行
p        #粘貼
u        #撤銷上一個操做
r        #替換當前字符:先按r,再按目標字符
/        #查找關鍵字,n在結果之間切換

#插入模式:命令模式下按i進入插入模式

#ex模式:命令模式按":"進入ex模式
:w            #保存當前修改
:q            #退出
:q!            #強制退出,不保存修改
:x            #保存並退出,至關於:wq
:set number    #顯示行號
:!系統命令    #執行一個系統命令並顯示結果
:sh            #切換到命令行,使用ctrl+d切換vim


<源代碼軟件安裝>
./configure                #檢查編譯環境、相關庫文件以及配置參數並生成makefile
#./configure --help     #獲取配置幫助
make                    #對源代碼進行編譯,生成可執行文件
make install            #將生成的可執行文件安裝到當前的計算機中

<rpm基礎命令>
rpm -i software.rpm            #安裝軟件
rpm -e software                #卸載軟件,只跟程序名字
rpm -U software-new.rpm        #升級形式的安裝
rpm -ivh http://www.nobsu.net/software.rpm        #經過http或ftp協議安裝軟件
#rpm相關參數
-v        #顯示相關信息
-h        #顯示進度條
#RPM查詢
rpm -qa                    #列出全部安裝的rpm軟件
rpm -qf filename        #查詢目標文件處於哪一個rpm包
rpm -qi packagename        #查詢指定已安裝rpm軟件的信息
rpm -ql packagename        #查詢指定已安裝rpm軟件包含的文件
#上面四個是查詢已安裝的文件,下面是在rpm倉庫中查詢
rpm -qip software.rpm    #查詢rpm文件的信息
rpm -qlp software.rpm    #查詢rpm文件中包含的文件

#常見的用法:
rpm -qa | grep telnet        #查詢已安裝的telnet相關程序

<yum基本命令>
yum install software-name        #安裝軟件
yum remove software-name        #卸載軟件
yum update software-name        #升級指定軟件
#yum查詢
yum search keyword            #搜索
yum list (all|installed|recent|updates)        #列出所有、安裝的、最近的、軟件更新
yum info packagename        #顯示指定軟件信息,做用同rpm -qi software-name(已安裝)和rpm -qip software.rpm(未安裝)
yum whatprovides filename    #查詢哪一個rpm軟件包含目標文件

#建立本地yum倉庫
mkdir /local-yum-repo        #建立一個本地目錄
cp -rv /media/CentOS_6.5_Final/Packages/* /local-yum-repo/        #把掛載的IOS鏡像中的全部rpm包拷貝到本地目錄
cd /local-yum-repo/            #進入建立的目錄
ls -l | wc -l                #查看當前目錄下的文件數目,這裏3063

#使用createrepo命令對當前目錄進行索引,createrepo須要安裝見最後
#createrepo -v /local-yum-repo    #運行命令,-v顯示詳細信息
#若是有分組信息,則在運行命令的時候使用-g參數指定分組文件
#createrepo -g /tmp/*comps.xml /local-yum-repo
#最終使用下面的命令
createrepo -vg /media/CentOS_6.5_Final/repodata/*comps.xml .

ls -ld repodata        #建立索引後出現一個repodata目錄,裏面包含幾個索引文件
cd /etc/yum.repo.d/    #切換目錄
vim local-yum.repo    #建立本地yum源的配置文件
#內容以下:
    [linuxCast]
    name = LinuxCast yum local repo
    baseurl = file:///local-yum-repo/
    enabled = 1
    gpgcheck = 0
yum clean all        #每次更新yum後都要清除緩存
yum list            #驗證倉庫信息
#CentOS/RHEL的分組信息保存在光盤的repodata/目錄下,文件名以comps.xml結尾的xml文件
#建立完畢經過file方式直接使用,也能夠做爲對外的YUM倉庫,經過HTTP,FTP共享出去

rpm -ivh createrepo-0.9.9-18.el6.noarch.rpm        #安裝須要解決手動依賴

<<更改163的yum源>>
1.#下載CentOS-Base-163.repo, 
    http://mirrors.163.com/.help/centos.html
#放入
cd /etc/yum.repos.d
cp CentOS-Base-163.repo ./
2.運行yum makecache生成緩存
3.yum search softwarename 查找軟件
4.yum list softwarename 列出已裝軟件
5.yum install softwarename 安裝軟件
6.yun remove softwarename 卸載軟件
(sohu yum源: http://mirrors.shou.com,使用方法相同)
#配置網卡ip:
ifconfig eth0 192.168.10.1 netmask 255.255.255.0  #配置網eth0網卡的ip和子網掩碼


<<阿里雲文檔=配置163的yum源>>
http://help.aliyun.com/view/11108189_13435402.html?spm=0.0.0.0.tB8ExG
1.導入CentOS-6的GPG證書
#rpm --import http://mirrors.163.com/centos/RPM-GPG-KEY-CentOS-6

2.讓yum使用網易的源:
#cd /etc/yum.repos.d/
#wget http://mirrors.163.com/.help/CentOS-Base-163.repo

3.修改repo文件
在全部mirrorlist前面加上#,把全部$releasever替換成6,保存
#sed -i '/mirrorlist/d' CentOS-Base-163.repo
#sed -i '/\[addons\]/,/^$/d' CentOS-Base-163.repo
#sed -i 's/\$releasever/6/' CentOS-Base-163.repo
#sed -i 's/RPM-GPG-KEY-CentOS-5/RPM-GPG-KEY-CentOS-6/' CentOS-Base-163.repo

4.清理並從新生成yum緩存
#yum clean metadata
#yum makecache

===============================================================

<<編譯安裝apache>>
先去網上下載四個文件
一、apr-1.4.6.tar.gz
二、apr-util-1.5.1.tar.gz
三、pcre-8.32.tar.gz
四、httpd-2.4.3.tar.gz
這些都是安裝Apache必須的文件,並且很好下載。

http://pan.baidu.com/share/link?shareid=169366&uk=1829018343
這個是我上傳的,截至到2013-01-10日這些文件都是最新的版本

一、apr-1.4.6.tar.gz
tar xzf apr-1.4.6.tar.gz
./configure –prefix=/usr/local/apr
make && make install

二、  apr-util-1.5.1.tar.gz
tar xzf apr-util-1.5.1.tar.gz
.configure –with-apr=/usr/local/apr
make && make install

三、  prce
tar xzf pcre-8.32.tar.gz
./configure –prefix=/usr/local/prce
make && make install 

(若是上面安裝過程出現/bin/rm: cannot remove `libtoolT’: No such file or directory這個問題,解決辦法 vi configure 找到$RM 「$cfgfile」這行刪掉)

四、  apache
tar xzf httpd-2.4.3.tar.gz
./configure -prefix=/usr/local/apache --with-apr=/usr/local/apr/ --with-pcre=/usr/local/pcre/
make && make install

檢查一下apache是否正確安裝
/usr/local/apache/bin/apachectl -t
(出現AH00557: httpd: apr_sockaddr_info_get() failed for Chunk3這個問題,解決辦法, vi /usr/local/apache/conf/httpd.conf 找到#ServerName www.example.com:80 這行,把註釋拿掉,而後改爲ServerName localhost:80)

啓動apache
 service httpd start
(出現httpd: unrecognized service這個問題,解決辦法
         #cd /usr/local/apache/bin/
         #cp apachectl /etc/rc.d/init.d/httpd
         #vi /etc/rc.d/init.d/httpd
         在#!/bin/sh這行下增長
         # chkconfig: 2345 50 90
         # description:Activates/Deactivates Apache Web Server)





[linux系統經常使用命令大全]
http://help.aliyun.com/view/11108189_13435469.html?spm=0.0.0.0.BH5Y2Y
********************************************************************
系統信息:
arch 顯示機器的處理器架構(1) 
uname -m 顯示機器的處理器架構(2) 
uname -r 顯示正在使用的內核版本 
dmidecode -q 顯示硬件系統部件 - (SMBIOS / DMI) 
hdparm -i /dev/hda 羅列一個磁盤的架構特性 
hdparm -tT /dev/sda 在磁盤上執行測試性讀取操做 
cat /proc/cpuinfo 顯示CPU info的信息 
cat /proc/interrupts 顯示中斷 
cat /proc/meminfo 校驗內存使用 
cat /proc/swaps 顯示哪些swap被使用 
cat /proc/version 顯示內核的版本 
cat /proc/net/dev 顯示網絡適配器及統計 
cat /proc/mounts 顯示已加載的文件系統 
lspci -tv 羅列 PCI 設備 
lsusb -tv 顯示 USB 設備 
date 顯示系統日期 
cal 2007 顯示2007年的日曆表 
date 041217002007.00 設置日期和時間 - 月日時分年.秒 
clock -w 將時間修改保存到 BIOS 

關機 (系統的關機、重啓以及登出 ) 
shutdown -h now 關閉系統(1) 
init 0 關閉系統(2) 
telinit 0 關閉系統(3) 
shutdown -h hours:minutes & 按預約時間關閉系統 
shutdown -c 取消按預約時間關閉系統 
shutdown -r now 重啓(1) 
reboot 重啓(2) 
logout 註銷 

文件和目錄 
cd /home 進入 '/ home' 目錄' 
cd .. 返回上一級目錄 
cd ../.. 返回上兩級目錄 
cd 進入我的的主目錄 
cd ~user1 進入我的的主目錄 
cd - 返回上次所在的目錄 
pwd 顯示工做路徑 
ls 查看目錄中的文件 
ls -F 查看目錄中的文件 
ls -l 顯示文件和目錄的詳細資料 
ls -a 顯示隱藏文件 
ls *[0-9]* 顯示包含數字的文件名和目錄名 
tree 顯示文件和目錄由根目錄開始的樹形結構(1) 
lstree 顯示文件和目錄由根目錄開始的樹形結構(2) 
mkdir dir1 建立一個叫作 'dir1' 的目錄' 
mkdir dir1 dir2 同時建立兩個目錄 
mkdir -p /tmp/dir1/dir2 建立一個目錄樹 
rm -f file1 刪除一個叫作 'file1' 的文件' 
rmdir dir1 刪除一個叫作 'dir1' 的目錄' 
rm -rf dir1 刪除一個叫作 'dir1' 的目錄並同時刪除其內容 
rm -rf dir1 dir2 同時刪除兩個目錄及它們的內容 
mv dir1 new_dir 重命名/移動 一個目錄 
cp file1 file2 複製一個文件 
cp dir/* . 複製一個目錄下的全部文件到當前工做目錄 
cp -a /tmp/dir1 . 複製一個目錄到當前工做目錄 
cp -a dir1 dir2 複製一個目錄 
ln -s file1 lnk1 建立一個指向文件或目錄的軟連接 
ln file1 lnk1 建立一個指向文件或目錄的物理連接 
touch -t 0712250000 file1 修改一個文件或目錄的時間戳 - (YYMMDDhhmm) 
file file1 outputs the mime type of the file as text 
iconv -l 列出已知的編碼 
iconv -f fromEncoding -t toEncoding inputFile > outputFile creates anew from the given input file by assuming it is encoded in fromEncodingand converting it to toEncoding. 
find . -maxdepth 1 -name *.jpg -print -exec convert "{}" -resize 80x60"thumbs/{}" \; batch resize files in the current directory and send themto a thumbnails directory (requires convert from Imagemagick) 

文件搜索 
find / -name file1 從 '/' 開始進入根文件系統搜索文件和目錄 
find / -user user1 搜索屬於用戶 'user1' 的文件和目錄 
find /home/user1 -name \*.bin 在目錄 '/ home/user1' 中搜索帶有'.bin' 結尾的文件 
find /usr/bin -type f -atime  100 搜索在過去100天內未被使用過的執行文件 
find /usr/bin -type f -mtime -10 搜索在10天內被建立或者修改過的文件 
find / -name \*.rpm -exec chmod 755 '{}' \; 搜索以 '.rpm' 結尾的文件並定義其權限 
find / -xdev -name \*.rpm 搜索以 '.rpm' 結尾的文件,忽略光驅、捷盤等可移動設備 
locate \*.ps 尋找以 '.ps' 結尾的文件 - 先運行 'updatedb' 命令 
whereis halt 顯示一個二進制文件、源碼或man的位置 
which halt 顯示一個二進制文件或可執行文件的完整路徑 

掛載一個文件系統 
mount /dev/hda2 /mnt/hda2 掛載一個叫作hda2的盤 - 肯定目錄 '/ mnt/hda2' 已經存在 
umount /dev/hda2 卸載一個叫作hda2的盤 - 先從掛載點 '/ mnt/hda2' 退出 
fuser -km /mnt/hda2 當設備繁忙時強制卸載 
umount -n /mnt/hda2 運行卸載操做而不寫入 /etc/mtab 文件- 當文件爲只讀或當磁盤寫滿時很是有用 
mount /dev/fd0 /mnt/floppy 掛載一個軟盤 
mount /dev/cdrom /mnt/cdrom 掛載一個cdrom或dvdrom 
mount /dev/hdc /mnt/cdrecorder 掛載一個cdrw或dvdrom 
mount /dev/hdb /mnt/cdrecorder 掛載一個cdrw或dvdrom 
mount -o loop file.iso /mnt/cdrom 掛載一個文件或ISO鏡像文件 
mount -t vfat /dev/hda5 /mnt/hda5 掛載一個Windows FAT32文件系統 
mount /dev/sda1 /mnt/usbdisk 掛載一個usb 捷盤或閃存設備 
mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share 掛載一個windows網絡共享 

磁盤空間 
df -h 顯示已經掛載的分區列表 
ls -lSr |more 以尺寸大小排列文件和目錄 
du -sh dir1 估算目錄 'dir1' 已經使用的磁盤空間' 
du -sk * | sort -rn 以容量大小爲依據依次顯示文件和目錄的大小 
rpm -q -a --qf '{SIZE}t%{NAME}n' | sort -k1,1n 以大小爲依據依次顯示已安裝的rpm包所使用的空間 (fedora, redhat類系統) 
dpkg-query -W -f='${Installed-Size;10}t${Package}n' | sort -k1,1n 以大小爲依據顯示已安裝的deb包所使用的空間 (ubuntu, debian類系統) 

返回頂部索引 ^

用戶和羣組 
groupadd group_name 建立一個新用戶組 
groupdel group_name 刪除一個用戶組 
groupmod -n new_group_name old_group_name 重命名一個用戶組 
useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1 建立一個屬於 "admin" 用戶組的用戶 
useradd user1 建立一個新用戶 
userdel -r user1 刪除一個用戶 ( '-r' 排除主目錄) 
usermod -c "User FTP" -g system -d /ftp/user1 -s /bin/nologin user1 修改用戶屬性 
passwd 修改口令 
passwd user1 修改一個用戶的口令 (只容許root執行) 
chage -E 2005-12-31 user1 設置用戶口令的失效期限 
pwck 檢查 '/etc/passwd' 的文件格式和語法修正以及存在的用戶 
grpck 檢查 '/etc/passwd' 的文件格式和語法修正以及存在的羣組 
newgrp group_name 登錄進一個新的羣組以改變新建立文件的預設羣組 

返回頂部索引 ^

文件的權限 - 使用 " " 設置權限,使用 "-" 用於取消 
ls -lh 顯示權限 
ls /tmp | pr -T5 -W$COLUMNS 將終端劃分紅5欄顯示 
chmod ugo rwx directory1 設置目錄的全部人(u)、羣組(g)以及其餘人(o)以讀(r )、寫(w)和執行(x)的權限 
chmod go-rwx directory1 刪除羣組(g)與其餘人(o)對目錄的讀寫執行權限 
chown user1 file1 改變一個文件的全部人屬性 
chown -R user1 directory1 改變一個目錄的全部人屬性並同時改變改目錄下全部文件的屬性 
chgrp group1 file1 改變文件的羣組 
chown user1:group1 file1 改變一個文件的全部人和羣組屬性 
find / -perm -u s 羅列一個系統中全部使用了SUID控制的文件 
chmod u s /bin/file1 設置一個二進制文件的 SUID 位 - 運行該文件的用戶也被賦予和全部者一樣的權限 
chmod u-s /bin/file1 禁用一個二進制文件的 SUID位 
chmod g s /home/public 設置一個目錄的SGID 位 - 相似SUID ,不過這是針對目錄的 
chmod g-s /home/public 禁用一個目錄的 SGID 位 
chmod o t /home/public 設置一個文件的 STIKY 位 - 只容許合法全部人刪除文件 
chmod o-t /home/public 禁用一個目錄的 STIKY 位 

返回頂部索引 ^

文件的特殊屬性 - 使用 " " 設置權限,使用 "-" 用於取消 
chattr  a file1 只容許以追加方式讀寫文件 
chattr  c file1 容許這個文件能被內核自動壓縮/解壓 
chattr  d file1 在進行文件系統備份時,dump程序將忽略這個文件 
chattr  i file1 設置成不可變的文件,不能被刪除、修改、重命名或者連接 
chattr  s file1 容許一個文件被安全地刪除 
chattr  S file1 一旦應用程序對這個文件執行了寫操做,使系統馬上把修改的結果寫到磁盤 
chattr  u file1 若文件被刪除,系統會容許你在之後恢復這個被刪除的文件 
lsattr 顯示特殊的屬性 

返回頂部索引 ^

打包和壓縮文件 
bunzip2 file1.bz2 解壓一個叫作 'file1.bz2'的文件 
bzip2 file1 壓縮一個叫作 'file1' 的文件 
gunzip file1.gz 解壓一個叫作 'file1.gz'的文件 
gzip file1 壓縮一個叫作 'file1'的文件 
gzip -9 file1 最大程度壓縮 
rar a file1.rar test_file 建立一個叫作 'file1.rar' 的包 
rar a file1.rar file1 file2 dir1 同時壓縮 'file1', 'file2' 以及目錄 'dir1' 
rar x file1.rar 解壓rar包 
unrar x file1.rar 解壓rar包 
tar -cvf archive.tar file1 建立一個非壓縮的 tarball 
tar -cvf archive.tar file1 file2 dir1 建立一個包含了 'file1', 'file2' 以及 'dir1'的檔案文件 
tar -tf archive.tar 顯示一個包中的內容 
tar -xvf archive.tar 釋放一個包 
tar -xvf archive.tar -C /tmp 將壓縮包釋放到 /tmp目錄下 
tar -cvfj archive.tar.bz2 dir1 建立一個bzip2格式的壓縮包 
tar -xvfj archive.tar.bz2 解壓一個bzip2格式的壓縮包 
tar -cvfz archive.tar.gz dir1 建立一個gzip格式的壓縮包 
tar -xvfz archive.tar.gz 解壓一個gzip格式的壓縮包 
zip file1.zip file1 建立一個zip格式的壓縮包 
zip -r file1.zip file1 file2 dir1 將幾個文件和目錄同時壓縮成一個zip格式的壓縮包 
unzip file1.zip 解壓一個zip格式壓縮包 

返回頂部索引 ^

RPM 包 - (Fedora, Redhat及相似系統) 
rpm -ivh package.rpm 安裝一個rpm包 
rpm -ivh --nodeeps package.rpm 安裝一個rpm包而忽略依賴關係警告 
rpm -U package.rpm 更新一個rpm包但不改變其配置文件 
rpm -F package.rpm 更新一個肯定已經安裝的rpm包 
rpm -e package_name.rpm 刪除一個rpm包 
rpm -qa 顯示系統中全部已經安裝的rpm包 
rpm -qa | grep httpd 顯示全部名稱中包含 "httpd" 字樣的rpm包 
rpm -qi package_name 獲取一個已安裝包的特殊信息 
rpm -qg "System Environment/Daemons" 顯示一個組件的rpm包 
rpm -ql package_name 顯示一個已經安裝的rpm包提供的文件列表 
rpm -qc package_name 顯示一個已經安裝的rpm包提供的配置文件列表 
rpm -q package_name --whatrequires 顯示與一個rpm包存在依賴關係的列表 
rpm -q package_name --whatprovides 顯示一個rpm包所佔的體積 
rpm -q package_name --scripts 顯示在安裝/刪除期間所執行的腳本l 
rpm -q package_name --changelog 顯示一個rpm包的修改歷史 
rpm -qf /etc/httpd/conf/httpd.conf 確認所給的文件由哪一個rpm包所提供 
rpm -qp package.rpm -l 顯示由一個還沒有安裝的rpm包提供的文件列表 
rpm --import /media/cdrom/RPM-GPG-KEY 導入公鑰數字證書 
rpm --checksig package.rpm 確認一個rpm包的完整性 
rpm -qa gpg-pubkey 確認已安裝的全部rpm包的完整性 
rpm -V package_name 檢查文件尺寸、 許可、類型、全部者、羣組、MD5檢查以及最後修改時間 
rpm -Va 檢查系統中全部已安裝的rpm包- 當心使用 
rpm -Vp package.rpm 確認一個rpm包還未安裝 
rpm2cpio package.rpm | cpio --extract --make-directories *bin* 從一個rpm包運行可執行文件 
rpm -ivh /usr/src/redhat/RPMS/`arch`/package.rpm 從一個rpm源碼安裝一個構建好的包 
rpmbuild --rebuild package_name.src.rpm 從一個rpm源碼構建一個 rpm 包 

返回頂部索引 ^

YUM 軟件包升級器 - (Fedora, RedHat及相似系統) 
yum install package_name 下載並安裝一個rpm包 
yum localinstall package_name.rpm 將安裝一個rpm包,使用你本身的軟件倉庫爲你解決全部依賴關係 
yum update package_name.rpm 更新當前系統中全部安裝的rpm包 
yum update package_name 更新一個rpm包 
yum remove package_name 刪除一個rpm包 
yum list 列出當前系統中安裝的全部包 
yum search package_name 在rpm倉庫中搜尋軟件包 
yum clean packages 清理rpm緩存刪除下載的包 
yum clean headers 刪除全部頭文件 
yum clean all 刪除全部緩存的包和頭文件 

返回頂部索引 ^

DEB 包 (Debian, Ubuntu 以及相似系統) 
dpkg -i package.deb 安裝/更新一個 deb 包 
dpkg -r package_name 從系統刪除一個 deb 包 
dpkg -l 顯示系統中全部已經安裝的 deb 包 
dpkg -l | grep httpd 顯示全部名稱中包含 "httpd" 字樣的deb包 
dpkg -s package_name 得到已經安裝在系統中一個特殊包的信息 
dpkg -L package_name 顯示系統中已經安裝的一個deb包所提供的文件列表 
dpkg --contents package.deb 顯示還沒有安裝的一個包所提供的文件列表 
dpkg -S /bin/ping 確認所給的文件由哪一個deb包提供 

返回頂部索引 ^

APT 軟件工具 (Debian, Ubuntu 以及相似系統) 
apt-get install package_name 安裝/更新一個 deb 包 
apt-cdrom install package_name 從光盤安裝/更新一個 deb 包 
apt-get update 升級列表中的軟件包 
apt-get upgrade 升級全部已安裝的軟件 
apt-get remove package_name 從系統刪除一個deb包 
apt-get check 確認依賴的軟件倉庫正確 
apt-get clean 從下載的軟件包中清理緩存 
apt-cache search searched-package 返回包含所要搜索字符串的軟件包名稱 

返回頂部索引 ^

查看文件內容 
cat file1 從第一個字節開始正向查看文件的內容 
tac file1 從最後一行開始反向查看一個文件的內容 
more file1 查看一個長文件的內容 
less file1 相似於 'more' 命令,可是它容許在文件中和正向操做同樣的反向操做 
head -2 file1 查看一個文件的前兩行 
tail -2 file1 查看一個文件的最後兩行 
tail -f /var/log/messages 實時查看被添加到一個文件中的內容 

返回頂部索引 ^

文本處理 
cat file1 file2 ... | command <> file1_in.txt_or_file1_out.txtgeneral syntax for text manipulation using PIPE, STDIN and STDOUT 
cat file1 | command( sed, grep, awk, grep, etc...) > result.txt 合併一個文件的詳細說明文本,並將簡介寫入一個新文件中 
cat file1 | command( sed, grep, awk, grep, etc...) >> result.txt 合併一個文件的詳細說明文本,並將簡介寫入一個已有的文件中 
grep Aug /var/log/messages 在文件 '/var/log/messages'中查找關鍵詞"Aug" 
grep ^Aug /var/log/messages 在文件 '/var/log/messages'中查找以"Aug"開始的詞彙 
grep [0-9] /var/log/messages 選擇 '/var/log/messages' 文件中全部包含數字的行 
grep Aug -R /var/log/* 在目錄 '/var/log' 及隨後的目錄中搜索字符串"Aug" 
sed 's/stringa1/stringa2/g' example.txt 將example.txt文件中的 "string1" 替換成 "string2" 
sed '/^$/d' example.txt 從example.txt文件中刪除全部空白行 
sed '/ *#/d; /^$/d' example.txt 從example.txt文件中刪除全部註釋和空白行 
echo 'esempio' | tr '[:lower:]' '[:upper:]' 合併上下單元格內容 
sed -e '1d' result.txt 從文件example.txt 中排除第一行 
sed -n '/stringa1/p' 查看只包含詞彙 "string1"的行 
sed -e 's/ *$//' example.txt 刪除每一行最後的空白字符 
sed -e 's/stringa1//g' example.txt 從文檔中只刪除詞彙 "string1" 並保留剩餘所有 
sed -n '1,5p;5q' example.txt 查看從第一行到第5行內容 
sed -n '5p;5q' example.txt 查看第5行 
sed -e 's/00*/0/g' example.txt 用單個零替換多個零 
cat -n file1 標示文件的行數 
cat example.txt | awk 'NR%2==1' 刪除example.txt文件中的全部偶數行 
echo a b c | awk '{print $1}' 查看一行第一欄 
echo a b c | awk '{print $1,$3}' 查看一行的第一和第三欄 
paste file1 file2 合併兩個文件或兩欄的內容 
paste -d ' ' file1 file2 合併兩個文件或兩欄的內容,中間用" "區分 
sort file1 file2 排序兩個文件的內容 
sort file1 file2 | uniq 取出兩個文件的並集(重複的行只保留一份) 
sort file1 file2 | uniq -u 刪除交集,留下其餘的行 
sort file1 file2 | uniq -d 取出兩個文件的交集(只留下同時存在於兩個文件中的文件) 
comm -1 file1 file2 比較兩個文件的內容只刪除 'file1' 所包含的內容 
comm -2 file1 file2 比較兩個文件的內容只刪除 'file2' 所包含的內容 
comm -3 file1 file2 比較兩個文件的內容只刪除兩個文件共有的部分 

返回頂部索引 ^

字符設置和文件格式轉換 
dos2unix filedos.txt fileunix.txt 將一個文本文件的格式從MSDOS轉換成UNIX 
unix2dos fileunix.txt filedos.txt 將一個文本文件的格式從UNIX轉換成MSDOS 
recode ..HTML < page.txt > page.html 將一個文本文件轉換成html 
recode -l | more 顯示全部容許的轉換格式 

返回頂部索引 ^

文件系統分析 
badblocks -v /dev/hda1 檢查磁盤hda1上的壞磁塊 
fsck /dev/hda1 修復/檢查hda1磁盤上linux文件系統的完整性 
fsck.ext2 /dev/hda1 修復/檢查hda1磁盤上ext2文件系統的完整性 
e2fsck /dev/hda1 修復/檢查hda1磁盤上ext2文件系統的完整性 
e2fsck -j /dev/hda1 修復/檢查hda1磁盤上ext3文件系統的完整性 
fsck.ext3 /dev/hda1 修復/檢查hda1磁盤上ext3文件系統的完整性 
fsck.vfat /dev/hda1 修復/檢查hda1磁盤上fat文件系統的完整性 
fsck.msdos /dev/hda1 修復/檢查hda1磁盤上dos文件系統的完整性 
dosfsck /dev/hda1 修復/檢查hda1磁盤上dos文件系統的完整性 

返回頂部索引 ^

初始化一個文件系統 
mkfs /dev/hda1 在hda1分區建立一個文件系統 
mke2fs /dev/hda1 在hda1分區建立一個linux ext2的文件系統 
mke2fs -j /dev/hda1 在hda1分區建立一個linux ext3(日誌型)的文件系統 
mkfs -t vfat 32 -F /dev/hda1 建立一個 FAT32 文件系統 
fdformat -n /dev/fd0 格式化一個軟盤 
mkswap /dev/hda3 建立一個swap文件系統 

返回頂部索引 ^

SWAP文件系統 
mkswap /dev/hda3 建立一個swap文件系統 
swapon /dev/hda3 啓用一個新的swap文件系統 
swapon /dev/hda2 /dev/hdb3 啓用兩個swap分區 

返回頂部索引 ^

備份 
dump -0aj -f /tmp/home0.bak /home 製做一個 '/home' 目錄的完整備份 
dump -1aj -f /tmp/home0.bak /home 製做一個 '/home' 目錄的交互式備份 
restore -if /tmp/home0.bak 還原一個交互式備份 
rsync -rogpav --delete /home /tmp 同步兩邊的目錄 
rsync -rogpav -e ssh --delete /home ip_address:/tmp 經過SSH通道rsync 
rsync -az -e ssh --delete ip_addr:/home/public /home/local 經過ssh和壓縮將一個遠程目錄同步到本地目錄 
rsync -az -e ssh --delete /home/local ip_addr:/home/public 經過ssh和壓縮將本地目錄同步到遠程目錄 
dd bs=1M if=/dev/hda | gzip | ssh user@ip_addr 'dd of=hda.gz' 經過ssh在遠程主機上執行一次備份本地磁盤的操做 
dd if=/dev/sda of=/tmp/file1 備份磁盤內容到一個文件 
tar -Puf backup.tar /home/user 執行一次對 '/home/user' 目錄的交互式備份操做 
( cd /tmp/local/ && tar c . ) | ssh -C user@ip_addr 'cd /home/share/ && tar x -p' 經過ssh在遠程目錄中複製一個目錄內容 
( tar c /home ) | ssh -C user@ip_addr 'cd /home/backup-home && tar x -p' 經過ssh在遠程目錄中複製一個本地目錄 
tar cf - . | (cd /tmp/backup ; tar xf - ) 本地將一個目錄複製到另外一個地方,保留原有權限及連接 
find /home/user1 -name '*.txt' | xargs cp -av --target-directory=/home/backup/ --parents 從一個目錄查找並複製全部以 '.txt' 結尾的文件到另外一個目錄 
find /var/log -name '*.log' | tar cv --files-from=- | bzip2 > log.tar.bz2 查找全部以 '.log' 結尾的文件並作成一個bzip包 
dd if=/dev/hda of=/dev/fd0 bs=512 count=1 作一個將 MBR (Master Boot Record)內容複製到軟盤的動做 
dd if=/dev/fd0 of=/dev/hda bs=512 count=1 從已經保存到軟盤的備份中恢復MBR內容 

返回頂部索引 ^

光盤 
cdrecord -v gracetime=2 dev=/dev/cdrom -eject blank=fast -force 清空一個可複寫的光盤內容 
mkisofs /dev/cdrom > cd.iso 在磁盤上建立一個光盤的iso鏡像文件 
mkisofs /dev/cdrom | gzip > cd_iso.gz 在磁盤上建立一個壓縮了的光盤iso鏡像文件 
mkisofs -J -allow-leading-dots -R -V "Label CD" -iso-level 4 -o ./cd.iso data_cd 建立一個目錄的iso鏡像文件 
cdrecord -v dev=/dev/cdrom cd.iso 刻錄一個ISO鏡像文件 
gzip -dc cd_iso.gz | cdrecord dev=/dev/cdrom - 刻錄一個壓縮了的ISO鏡像文件 
mount -o loop cd.iso /mnt/iso 掛載一個ISO鏡像文件 
cd-paranoia -B 從一個CD光盤轉錄音軌到 wav 文件中 
cd-paranoia -- "-3" 從一個CD光盤轉錄音軌到 wav 文件中(參數-3) 
cdrecord --scanbus 掃描總線以識別scsi通道 
dd if=/dev/hdc | md5sum 校驗一個設備的md5sum編碼,例如一張 CD 


網絡 - (以太網和WIFI無線) 
ifconfig eth0 顯示一個以太網卡的配置 
ifup eth0 啓用一個 'eth0' 網絡設備 
ifdown eth0 禁用一個 'eth0' 網絡設備 
ifconfig eth0 192.168.1.1 netmask 255.255.255.0 控制IP地址 
ifconfig eth0 promisc 設置 'eth0' 成混雜模式以嗅探數據包 (sniffing) 
dhclient eth0 以dhcp模式啓用 'eth0' 
route -n show routing table 
route add -net 0/0 gw IP_Gateway configura default gateway 
route add -net 192.168.0.0 netmask 255.255.0.0 gw 192.168.1.1 configure static route to reach network '192.168.0.0/16' 
route del 0/0 gw IP_gateway remove static route 
echo "1" > /proc/sys/net/ipv4/ip_forward activate ip routing 
hostname show hostname of system 
host www.example.com lookup hostname to resolve name to ip address and viceversa(1) 
nslookup www.example.com lookup hostname to resolve name to ip address and viceversa(2) 
ip link show show link status of all interfaces 
mii-tool eth0 show link status of 'eth0' 
ethtool eth0 show statistics of network card 'eth0' 
netstat -tup show all active network connections and their PID 
netstat -tupl show all network services listening on the system and their PID 
tcpdump tcp port 80 show all HTTP traffic 
iwlist scan show wireless networks 
iwconfig eth1 show configuration of a wireless network card 
hostname show hostname 
host www.example.com lookup hostname to resolve name to ip address and viceversa 
nslookup www.example.com lookup hostname to resolve name to ip address and viceversa 
whois www.example.com lookup on Whois database 
相關文章
相關標籤/搜索