1. 程式人生 > >Linux常用命令和常見問題

Linux常用命令和常見問題

secure 格式 tmp目錄 prompt nat mys 常見問題 -c 文檔

常用命令

查看系統信息

Linux版本
uname -a 查看系統內核信息
lsb_release -a 查看LSB(Linux Standard Base)和Distribution信息
cat /etc/issue 查看Linux版本
cat /etc/system-release
cat /etc/redhat-release
env 顯示當前用戶的環境變量

CPU信息
lscpu - display information about the CPU architecture

cat /proc/cpuinfo
vmstat - reports information about processes, memory, paging, block IO, traps, disks and cpu activity
top

內存信息
cat /proc/meminfo

進程
ps -ef | grep java 查看Java進程
kill -9 #### 殺死進程
netstat -tlnp | grep 8080 查看端口占用
fuser Show which processes use the named files, sockets, or filesystems

fuser -k -n tcp 80 殺死占用80端口的進程

tmpwatch -afv 5d /tmp 刪除tmp目錄5天未使用的文件
update-alternatives --install /usr/bin/java java /usr/lib/jvm/jdk1.7.0/bin/java

添加Repository

CentOS/RHEL 7:

# rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

CentOS/RHEL 6:

# rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm

也可以到以下網站查找安裝包:
Package search
RPM Search
RPM Find

安裝開發工具包

yum install -y gcc gcc-c++ 安裝編譯器
yum install -y libstdc++ libstdc++-devel
yum groupinstall “Development Tools” 安裝Development Tools
(如出現there is no installed groups file錯誤,請附加參數--setopt=group_package_types=mandatory,default,optional)
yum groupinfo "Development Tools" 查看組Development Tools的內容
yum list installed 列出已安裝的包

firewall配置

systemctl start firewalld
firewall-cmd --state
firewall-cmd --zone=public --add-port=5000/tcp

用戶權限

visudo 編輯/etc/sudoers文件

文件/目錄操作

pwd 顯示當前工作路徑
cd - 返回上次所在的目錄
mkdir -p /dir1/dir2 創建一個目錄樹
cp -a dir1 dir2 復制一個目錄

true > test.txt 清空文件的內容
find
與時間有關的選項:-atime, -ctime 與 -mtime,以 -mtime 說明
-mtime n :n 為數字,意義為在 n 天之前的『一天之內』修改過內容的文件
-mtime +n :列出在 n 天之前(不含 n 天本身)修改過內容的文件
-mtime -n :列出在 n 天之內(含 n 天本身)修改過內容的文件
-newer file :file 為一個存在的文件,列出比 file 還要新的文件
CentOS 7 支持 -newerXY 參數,可直接指定時間,具體請查閱find幫助文檔。

find AIRLINE -name *0813* -type f | xargs du -ck  查找名字包含0813的文件並統計總大小,以Kb為單位
find執行action
find / -name \*.rpm -exec chmod 755 ‘{}‘ \;   從根目錄搜索以 ‘.rpm‘ 結尾的文件並定義其權限,其中{}位置放置find執行結果,\; 為action結束標誌
find -type d -exec mkdir -p /new_folder/{} \;   復制當前目錄下的目錄結構
find AIRLINE -wholename **/attach/*0813* -type f -exec rm -f {} \;  根據wholename查找文件並刪除

which [-a] command 尋找可執行文件(-a :將所有PATH 目錄中可以找到的命令均列出,而不止第一個被找到的命令名稱)
whereis [-bmsu] filename/folder 從一些特定的目錄查找
locate [-ir] keyword 依據/var/lib/mlocate資料庫的記載查找文件(執行updatedb更新資料庫)

常用配置文件

網絡配置

SSH /etc/ssh/sshd_config
網絡參數 /etc/sysconfig/network-scripts/ifcfg-eth0
DNS /etc/resolv.conf
hosts /etc/hosts
hostname /etc/hostname
network /etc/sysconfig/network

NETWORKING=yes  
NETWORKING_IPV6=no  
HOSTNAME=xxx  
GATEWAY=xxx.xxx.xxx.xxx  

iptables /etc/sysconfig/iptables

系統配置

mount /etc/fstab

用戶配置

user /etc/passwd
user password /etc/shadow
group /etc/group
group password /etc/gshadow

定時任務

/etc/cron.daily
/etc/cron.hourly
/etc/cron.monthly
/etc/cron.weekly
/etc/anacrontab

#period in days   delay in minutes   job-identifier          command
1                          5                          cron.daily              nice run-parts /etc/cron.daily
7                         25                         cron.weekly           nice run-parts /etc/cron.weekly
@monthly           45                         cron.monthly         nice run-parts /etc/cron.monthly

定時服務crond

service crond start/stop 啟動/停止定時服務

crontab 編輯定時任務
crontab [-u user] [ -e | -l | -r ]
-e edit user‘s crontab
-l list user‘s crontab
-r delete user‘s crontab
-ir prompt before deleting user‘s crontab

crontab [-u user] file
以file做為crontab的任務列表文件並載入

crontab file的格式:
crontab 文件中的行由 6 個字段組成,不同字段間用空格或 tab 鍵分隔。
前 5 個字段指定命令要運行的時間
分鐘 (0-59)
小時 (0-23)
日期 (1-31)
月份 (1-12)
星期幾(0-6,其中 0 代表星期日)
第 6 個字段是執行的字符串

常見問題

YUM duplicate錯誤

First look if you have any uncomplete transactions with: yum-complete-transaction
If this doesn‘t help then take a look at the package-cleanup tool which is part of the yum-utils package.
package-cleanup --dupes lists duplicate packages
package-cleanup --cleandupes removes duplicate packages

ldconfig動態鏈接庫管理

在找不到so文件時(cannot open shared object file),使用ldconfig來配置共享。配置文件位於/etc/ld.so.conf.d目錄下。
比如,安裝了mysql,so文件位於/usr/lib64/mysql下,可在/etc/ld.so.conf.d目錄創建mysql.conf文件,其中內容為 /usr/lib64/mysql,然後運行:
$ sudo ldconfig -v

linux時間同步

yum install ntp
service ntpd start

服務啟動後會自動從上級ntp服務器同步時間
/etc/ntp.conf為配置文件,可配置上級服務器

客戶端也可不啟動ntpd服務,通過crontab同步時間:

*/3 * * * *     (/usr/sbin/ntpdate 10.184.13.14 && /sbin/hwclock -w) &> /dev/null

設置時區

CentOS 7

$ timedatectl
Local time: Tue 2016-11-22 06:07:42 UTC  
Universal time: Tue 2016-11-22 06:07:42 UTC
RTC time: Tue 2016-11-22 06:07:42  
Time zone: UTC (UTC, +0000)  
NTP enabled: yes  
NTP synchronized: no  
RTC in local TZ: no  
DST active: n/a  

timedatectl list-timezones 查看時區
timedatectl set-timezone Asia/Shanghai 設置時區
timedatectl set-timezone UTC

CentOS 6

# vim /etc/sysconfig/clock
ZONE="UTC"
cp /usr/share/zoneinfo/UTC /etc/localtime

使用ssh-agent和keychain 緩存解密的密鑰

Keychain helps you to manage SSH and GPG keys in a convenient and secure manner. It acts as a frontend to ssh-agent and ssh-add, but allows you to easily have one long running ssh-agent process per system, rather than the norm of one ssh-agent per login session.

This dramatically reduces the number of times you need to enter your passphrase. With keychain, you only need to enter a passphrase once every time your local machine is rebooted. Keychain also makes it easy for remote cron jobs to securely "hook in" to a long-running ssh-agent process, allowing your scripts to take advantage of key-based logins.

限制多人用同一個用戶登錄

在/etc/pam.d/login中增加:

session required/lib/security/pam_limits.so

然後在/etc/security/limits.conf加入如下內容:

* hard maxlogins 1

數據恢復

安裝工具extundelete

yum install e2fsprogs e2fslibs-dev

或下載extundelete-x.x.x.tar.bz2,運行tar -jxvf extundelete-x.x.x.tar.bz2解壓後安裝。
恢復某一目錄,執行:

extundelete partition_name --restore-directory path/of/directory

autoexpect - generate an Expect script from watching a session
鳥哥的Linux私房菜
Top 5 Yum Repositories for CentOS/RHEL 7/6/5

Linux常用命令和常見問題