Linux
From ACL@NCU
Useful tcsh and python commands
tcsh
- Find files
with defined stem pattern under multiple different folder
find */*/*anat+tlrc.*
- find files with a suffix recursively under subdirectories
find . -name \*.mgz -print
- delete or copy filenames from a "pattern" search
rm `find */*/*anat+tlrc.*`
- comment multiple lines
:<<LABEL comment line #1 comment line #2 comment line #3 ... comment line #final LABEL
- Extract a substring [1]
- Split a string[2]
The awk function split(,,sep) splits a string into an awk array using the delimiter sep.
set time = 12:34:56 set hr = `echo $time | awk '{split($0,a,":"); print a[1]}'` # = 12 set sec = `echo $time | awk '{split($0,a,":"); print a[3]}'` # = 56
- Translation between bash and tcsh [3]
- Install R
To obtain the latest R packages, add an entry like
deb http://<my.favorite.cran.mirror>/bin/linux/ubuntu precise/
which for ubuntu 12.04 in Taiwan would be:
deb http://cran.csie.ntu.edu.tw/bin/linux/ubuntu precise/
in your /etc/apt/sources.list file, replacing <my.favorite.cran.mirror> by the actual URL of your favorite CRAN mirror. See http://cran.r-project.org/mirrors.html for the list of CRAN mirrors. To install the complete R system, use
sudo apt-get update sudo apt-get install r-base
alias <name> <actual commands !:1> #take the first argument
- list files without a string
ls -I '<pattern>.*'
file system
- Determine file creating and modification times [4]
stat *
Network Connection
- Blocking a port [5]
sudo ufw deny 80
- list all current ufw rules
sudo ufw status numbered
other ufw usage [6]
- Scanning available ports
nmap -PS <IP address>
- Scanning all available IPs in subnet
nmap -sP 192.168.1.0/24
- restart network GUI (allow the top-left icon of network to show up)
sudo service network-manager restart
To configure your system to use a static IP address assignment, add the static method to the inet address family statement for the appropriate interface in the file /etc/network/interfaces. The example below assumes you are configuring your first Ethernet interface identified as eth0. Change the address, netmask, and gateway values to meet the requirements of your network.
auto eth0 iface eth0 inet static address 10.0.0.100 netmask 255.255.255.0 gateway 10.0.0.1
Install new packages
- pip [7]
sudo apt-get install python-pip python-dev build-essential sudo pip install --upgrade pip sudo pip install --upgrade virtualenv
- apt-cache: search for the name of library package with keyword
apt-cache search libpcre
- add software sources to sources.list (in /etc/apt/sources.list)
#using octave as an example deb http://ppa.launchpad.net/octave/stable/ubuntu precise main deb-src http://ppa.launchpad.net/octave/stable/ubuntu precise main
- install python lxml on ubuntu (quite tricky if attempted from building source)
apt-get build-dep python-lxml pip install lxml
System Configuration
env
- set environmental varialbes in .tcshrc (or the like)
setenv VARNAME values
- reset root password
sudo passwd root
- hardware information
hwinfo
- tell current user
id
- tell the current shell
echo $SHELL
echo $SHELL
edit the /etc/environments file
First, boot into ubuntu with usb or cd images; then install boot-repair as instructed below:
sudo add-apt-repository ppa:yannubuntu/boot-repair && sudo apt-get update sudo apt-get install -y boot-repair && (boot-repair &)
- afni & R problem: Fail to load R_io.so
under where the directory where R is installed, start R and type:
dyn.load("R_io.so")
See what error message is spit out. For example:
> dyn.load("R_io.so") Error in dyn.load("R_io.so") : unable to load shared object '/usr/local/abin/R_io.so': libjpeg.so.62: cannot open shared object file: No such file or directory
This is a problem of not finding libjpeg.so.62, which can be resolved by:
sudo apt-get install libjpeg62 sudo apt-get install libjpeg62:i386
- Setup the default folder for sftp login:
sudo usermod -d [desired default path] username
- Change number of workspace
gconftool-2 -s /apps/metacity/general/num_workspaces --type int <n>
File I/O
sed -i 's/original/new/g' file.txt
- read out contents from multiple files and remove certain strings
find . -name "blur_est.*.1D" | xargs tail -n 1 | grep -v == | tr -s '\n'
- extract the first 3 column(s) from a text file
cut -f 1,2,3 -d ' '
VirtualBox
System Maintenance
- shutdown system after a certain amount of time
nohup sudo shutdown -h +<m> &
- view all processes
ps aux | less
#Change the Ubuntu code name from Raring Ringtail to Trusty Tahr sudo sed -i 's/raring/trusty/g' /etc/apt/sources.list # Disable third party PPAs (optional, see note) cd /etc/apt/sources.list.d sudo rename 's/(.*)/$1.bak/' * sudo find . -type f -name "*" -print | xargs sed -i 's/raring/trusty/g' # Update the repositories and upgrade sudo apt-get update && sudo apt-get dist-upgrade #Update grub and initramfs sudo update-grub && sudo update-initramfs -u
Frequently Encountered Problems (FEPs)
Situation: I can't seem to open my desktop anymore. After powering on my 64 bit ubuntu asus laptop I see the login screen and I can reach a desktop as guest (no password). However, using my normal user name and password brings me back to that same login page I just entered my password in.
Solution:
sudo chown user.usergroup ~/.Xauthority example sudo chown fred.fred ~/.Xauthority
#showing available modes (the active one with *) xrandr #setting the desired mode xrandr --output default --mode 1680x1050
The mode lines can be generated with the following syntax
cvt <h-resolution> <v-resolution> [refresh]