Linux install

Name:
Location: United States

Friday, February 29, 2008

how to setup no-password ssh login

1. Use ssh-keygen to generate a pair of public and private keys
ssh-keygen -t dsa # or -t rsa
it will generate a id_dsa and id_dsa.pub in ~/.ssh/ directory
2. Copy the public key to remote machine and add it to ~/.ssh/authorized_keys
cat id_dsa.pub>>authorized_keys
3. make sure authorized_keys has correct file attribute.
chmod 640 authorized_keys
chmod 700 .ssh


4. Or use puttygen to generate a key-pair and copy public key to the remote machine, if we use putty to login to the server.

5. Make sure you're using scp or ftp to copy the public key from one machine to another. Note Cut and paste may make the key not working. Use cat id_dsa.pub >>authorized_keys to add the additional keys.
6. Change file permission to 640, chmod 640 authorized_keys

Tuesday, February 26, 2008

/sbin/chkconfig --list --checking what services are enabled on certain run level

/sbin/chkconfig --list


services runlevel0 1 2 3 4 5 6
-----------------------------------------------------------

radvd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
bootparamd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
nfs 0:off 1:off 2:off 3:on 4:off 5:on 6:off
kudzu 0:off 1:off 2:off 3:off 4:on 5:on 6:off
cups-config-daemon 0:off 1:off 2:off 3:off 4:on 5:off 6:off
innd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
arpwatch 0:off 1:off 2:off 3:off 4:off 5:off 6:off
readahead_early 0:off 1:off 2:off 3:off 4:off 5:off 6:off
mysqld 0:off 1:off 2:off 3:off 4:off 5:off 6:off
ldap 0:off 1:off 2:off 3:off 4:off 5:off 6:off
vncserver 0:off 1:off 2:off 3:off 4:off 5:off 6:off
ypxfrd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
postgresql 0:off 1:off 2:off 3:off 4:off 5:off 6:off
spamassassin 0:off 1:off 2:off 3:off 4:off 5:off 6:off
canna 0:off 1:off 2:on 3:off 4:on 5:off 6:off
dhcp6s 0:off 1:off 2:off 3:off 4:off 5:off 6:off
rwhod 0:off 1:off 2:off 3:off 4:off 5:off 6:off
mdmonitor 0:off 1:off 2:on 3:off 4:on 5:on 6:off
mdmpd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
bgpd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
ntpd 0:off 1:off 2:off 3:off 4:off 5:on 6:off
radiusd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
microcode_ctl 0:off 1:off 2:on 3:off 4:on 5:on 6:off
netdump-server 0:off 1:off 2:off 3:off 4:off 5:off 6:off
squid 0:off 1:off 2:off 3:off 4:off 5:off 6:off
rpcsvcgssd 0:off 1:off 2:off 3:off 4:on 5:off 6:off
autofs 0:off 1:off 2:off 3:on 4:on 5:on 6:off
irda 0:off 1:off 2:off 3:off 4:off 5:off 6:off
psacct 0:off 1:off 2:off 3:off 4:off 5:off 6:off
nfslock 0:off 1:off 2:off 3:on 4:on 5:on 6:off
snmpd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
cpuspeed 0:off 1:on 2:on 3:off 4:on 5:on 6:off
yppasswdd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
rhnsd 0:off 1:off 2:off 3:off 4:on 5:off 6:off
netfs 0:off 1:off 2:off 3:on 4:on 5:on 6:off
xfs 0:off 1:off 2:on 3:on 4:on 5:on 6:off
sysstat 0:off 1:on 2:on 3:on 4:on 5:on 6:off
syslog 0:off 1:off 2:on 3:on 4:on 5:on 6:off
rstatd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
rawdevices 0:off 1:off 2:off 3:off 4:on 5:off 6:off
ospfd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
diskdump 0:off 1:off 2:off 3:off 4:off 5:off 6:off
rusersd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
sshd 0:off 1:off 2:on 3:on 4:on 5:on 6:off
zebra 0:off 1:off 2:off 3:off 4:off 5:off 6:off
kadmin 0:off 1:off 2:off 3:off 4:off 5:off 6:off
rpcgssd 0:off 1:off 2:off 3:off 4:on 5:off 6:off
krb5kdc 0:off 1:off 2:off 3:off 4:off 5:off 6:off
lm_sensors 0:off 1:off 2:on 3:off 4:on 5:off 6:off
amd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
snmptrapd 0:off 1:off 2:off 3:off 4:off 5:off 6:off


.............

xinetd based services:
ktalk: off
klogin: off
rlogin: off
chargen-udp: off
daytime-udp: off
kshell: off
talk: off
krb5-telnet: off
echo-udp: off
ntalk: off
cups-lpd: off
swat: off
eklogin: off
rsh: off
finger: off
daytime: off
telnet: off
time-udp: off
chargen: off
amidxtape: off
rsync: off
dbskkd-cdb: off
rexec: off
amanda: off
gssftp: off
tftp: on
auth: off
time: off
amandaidx: off
echo: off

Tuesday, February 19, 2008

How to compile Madwifi package

1. Download and unzip the madwifi package. eg. madwifi-ng-r3344-20080207.tar.gz
2. Run the following command,
make CROSS_COMPILE=powerpc-405-linux-gnu- KERNELPATH=/localhome/wli/linux-2.6.24 TARGET=powerpc-be-elf DESTDIR=/localhome/wli/rootfs install

where: CROSS_COMPILE=
powerpc-405-linux-gnu- specifies the cross-compiler prefix. Make sure cross-compiler path is exported and accessible to current user.
DESTDIR =root directory to install. Usually it's a path to root file system
TARGET= target processor and image format for cross compiling, powerpc, big-endian and elf
KERNELPATH= pah of kernel where the modules to be compiled with.
install -- install after compile. This will install the following modules in ~/rootfs/lib/modules/net/

ath_hal.ko ath_pci.ko ath_rate_amrr.ko ath_rate_minstrel.ko ath_rate_onoe.ko ath_rate_sample.ko wlan_acl.ko
wlan_ccmp.ko wlan.ko wlan_scan_ap.ko wlan_scan_sta.ko wlan_tkip.ko wlan_wep.ko wlan_xauth.ko
as well as WLAN command tools in ~/rootfs/usr/local/bin
80211debug 80211stats athchans athctrl athdebug ath_info athkey athstats madwifi-unload wlanconfig






3.. Run the following command,depmod.pl script to create modules.dep on the net module directory
../depmod.pl -b ~/rootfs/lib/modules/2.6.24/net -F ~/linux-2.6.24/System.map
This will generate modules.dep on net directory. It is needed by modprobe command.

Note: depmod.pl is a perl script from busybox-1.8.2 package.

Friday, February 15, 2008

How to cross compile ZLIB, OPENSSL, OPENSSH

ZLIB:
1. download zlib-1.2.3.tar.gz. Unzip it to /localhome/wli
2. cd zlib-1.2.3, run ./configure
3. Edit Makefile, change the following lines
CC=powerpc-405-linux-gnu-gcc
CPP=powerpc-405-linux-gnu-gcc -E
AR=powerpc-405-linux-gnu-ar rc
LDSHARED=powerpc-405-linux-gnu-gcc
prefix=/localhome/wli/rootfs/usr/local #this will install zlib into rootfs/usr/local
Note: rootfs--is the target machine root file system, in this case the target machine is powerpc-405

4. run make, make install, the zlib library will be installed to $prefix/lib

OpenSSL
1. download openssl-0.9.8g, unzip it to localhome/wli
2. run ./configure --openssldir=/localhome/wli/rootfs
3. Edit Make
AR=powerpc-405-linux-gnu-ar $(ARFLAGS) r
4. run make, make install

OpenSSH
1. download openssh-4.7p1, unzip it to localhome/wli
2. run run_configure script
./configure CC=powerpc-405-linux-gnu-gcc --host=ppc --build=powerpc-405-linux-gnu --with-ssl-dir=/localhome/wli/rootfs --w ith-zlib=/localhome/wli/rootfs --prefix=/localhome/wli/rootfs --disable-etc-default-login

3. Edit Makefile
AR=powerpc-405-linux-gnu-ar
LIBS=-lresolv -lcrypto -lutil -lz -lnsl -lcrypt # add -lcrypt
4. run make, make install

Monday, February 11, 2008

how to setup uboot enviroment variable for linux booting

Uboot needs to pass command line variables to linux kernel during bootstrapping the kernel.
1. NFS boot -- assume nfs rootfiles system is ready and exported by NFS server
a. set
nfs_boot=run nfsargs addbootfile addip;tftpboot $(kernel_addr) $(bootfile);bootm $(kernel_addr)
nfsargs=setenv bootargs root=/dev/nfs rw console=ttyS0,115200 mem=128M nfsroot=172.30.80.217:/localhome/wli/rootfs
addbootfile=setenv bootfile uImage_$(kernel_ver)
addip=setenv bootargs $(bootargs) ip=$(ipaddr):$(serverip):$(gatewayip):$(netmask):$(hostname):$(netdev):off panic=1
2. RAM boot
ram_boot=run ramargs addip;tftpboot $(kernel_addr) bootimg_f;bootm $(kernel_addr)
ramargs=setenv bootargs root=/dev/ram console=ttyS0,$(baudrate) ramdisk_size=20000

The bootfile is bootimg_f, which combine kernel image and root file system together.

flash unitil tools: flashcp,flash,erase,mkfs.jffs2.. compiling

1. Download mtd-utils-1.1.0.tar.bz2 package
2. This package contains utility for flash programing,erase and building flash file system
3. In order to compile this package, we need
libz.a --this package from zlib-1.2.3.tar.bz2
liblzo2.a --- this library comes from lzo package. Come download lzo-2.02.tar.gz2
4. Compile zlib to generate libz.a,compile lzo to generate liblzo2.a
5. Copy it to mtd-utils-1.1.0 directory

Friday, February 08, 2008

How to create an account on linux(username, password, home)

1. Loggin as root user, run
userdel -r wli #delete user wli and its home directory content
useradd -d /localhome/wli wli # home directory: /localhome/wli
passwd wli
##### type in new password here, say 123456

2. Log in as user wli