Skip to main content

[bash-script] vsz, rss logger for one process

#!/bin/bash
BIN_PROC_FILES="my_bin"
LOG_FILE=/tmp/memlog.log
RM_LOG_FILE=0
G_STDOUTPUT=1

function write_log
{
  CUR_TIME_STR=`date +"%Y%m%d_%H%M%S"`
  if [ ${G_STDOUTPUT} -gt 0 ]; then
    echo "${CUR_TIME_STR} $1"
  fi
  if [ "${LOG_FILE}" != "" ] ; then
    echo "${CUR_TIME_STR} $1" >> ${LOG_FILE}
  fi
}

function loop_proc
{
  for CUR_BIN in ${BIN_PROC_FILES}
  do
    PID_SNIPER=`pidof ${CUR_BIN}`
    if [ "${PID_SNIPER}" != "" ]; then
      MEM_STATS=`ps --pid ${PID_SNIPER} -o rss,vsz`
      LINE_CNT=`echo "${MEM_STATS}" | wc -l`
      if [ ${LINE_CNT} -gt 1 ]; then
        MEM_STAT=`echo "${MEM_STATS}" |tail -n 1`
      fi
      write_log "${CUR_BIN} ${PID_SNIPER} ${MEM_STAT}"
    fi
  done
}

if [ ${RM_LOG_FILE} -gt 0 ]; then
  if [ "${LOG_FILE}" != "" ] ; then
    rm ${LOG_FILE}
  fi
fi

while true
do
  loop_proc
  sleep 1
done

Comments

Popular posts from this blog

[scapy] Linux-Cooked pcap to ethernet

# The pcap file formatted by "Linux cooked" # tcpdump -r myfile.pcap -nn reading from file event1.pcap, link-type LINUX_SLL (Linux cooked) ... ... # step1. read myfile.pcap pkts = rdpcap("myfile.pcap"); # step2. read myfile.pcap pkts = [Ether(src='00:11:22:33:44:55', dst='22:33:44:55:66:77')/pkt[1:] for pkt in pkts] # step3. modify IP address and recalculate chksum for pkt in pkts:  pkt[1].dst='192.168.1.10';  pkt[1].src='192.168.1.1';  del pkt[IP].chksum  del pkt[UDP].chksum # step4. packet send sendp(pkts[0]); # step5. save pcap  wrpcap("output.pcap",pkts); # tcpdump -r output.pcap -nn reading from file output.pcap, link-type EN10MB (Ethernet) ... ... # pkt[1:] : It means IP layer 1) Before: Linux cooked / IP / UDP / UDP-Data 2) After: Ethernet / IP / UDP / UDP-Data

[WordPress] Change https redirect in DB.

If you make an https redirect without thinking about SSL configuration: Check DB SELECT * from wp_options where option_name IN ('siteurl', 'home'); Update UPDATE wp_options SET option_value = REPLACE(option_value, 'https://your_domain', 'http://your_domain') WHERE option_name IN ('siteurl', 'home');

[bash-script/gcc] check warning of make within git-diff of commit

When you need check "make warning" in specific commits, you can use this script to check just in some commits. This script takes some steps. step1. You must know your commit hash. : like abcd1234 step2. Checkout to your commit.  Like this, git checkout abcd1234. step3. You need output file that run make.  Try to run command "make &> myoutput" step4. Then run this. ./new_warning.sh abcd1234 myoutput You can download this script :  new_warning.sh