I started to begin a post about useful linux commands and command line tricks. It didn't take long for me to realize that would make a very very long post.
I'm going to start with some more common commands and some I've looked at recently. I expect this list to grow. For most of this I will list the command, my most common use(s) for it, and maybe some examples.
netstat
Useful for seeing what ports are open on your computer and what process is manning those ports. I might use this to make sure something like and ssh-server is running. Very useful on servers - dns,mail,web - for making sure your programs are configures to use the right ports.
netstat -natp
sudo netstat -natp|grep 'sshd'
ssh
If you don't know what this is for or how to use it, I don't see how anything else in this post will help you much.
traceroute
Traces the route a packet takes to get to a destination. I haven't found a really great regular/common use for it, but it is fun to run every once to a while to see where things are going, and what route they are taking.
traceroute www.google.com
mtr
It does the same as traceroute but it consistently pings each hop, and keeps track of packets - dropped, etc - can be useful for seeing where a connection may be getting hung up.
mtr www.google.com
xtightvncviewer
I use this all the time on my personal computers. I have one laptop that the battery doesn't work in, so it's always connected to the tv. It's nice to be able to connect to it from any other computer to change stuff. Or if I am trying to follow something my wife is doing on the computer and guide her through it I can connect in view only mode to always have a visual.
vncviewer remote.ip.addr[:port]
vncviewer -viewonly remote.ip.addr[:port]
whois
This can be useful, but like traceroute is mostly a curiosity thing. It will tell you who a particular ip address is registered to in the whois database.
whois ip.addr
nmap
This is a powerful great program that has many many uses. My most command is seeing things like what other computers are on the network and what services they are running. It scans the network and displays information.
nmap -v -sT -rF 192.168.0.0/24
The above command runs an nmap scan in verbose mode (-v -sT), scans the ip addresses between 192.168.0.0-255 (192.168.0.0/24), Scans in fast mode the most common ports (-F) and scans ports consecutively - not randomly (-r).
I use this with grep to show only the info on open ports.
If all I want to see is the open ssh ports on my network I can use -p22 instead of -rF
sshuttle
This is one great program. I had never heard of it until recently, but it's pretty much the bomb. It can do more but the first thing I've used it fore was to set connect to another computer (via ssh) and route all network traffic through the tunnel. (pretty much sets up a VPN for you via ssh). You can use it to get around dns blocks. Or if someone wants to join your LAN game who is not on your LAN sshuttle will put you on their network.
sshuttle -r <server> --dns 0/0
I did run into a little bit of trouble on ubuntu 12.04 my first time trying it and I actually had to run these comands on the client and server (both ubuntu 12.04)
sudo dpkg-reconfigure resolvconf (select yes on any prompts)
sudo resolvconf --enable-updates
sudo reboot
sshfs
mount an ssh filesystem, I already have this one in another post but here it is for redundancy. You can mount a folder from one computer to an empty folder on your computer. syntax is similar to scp
sshfs <server>:/path/to/source /path/to/destination
Well that's it for now, I'm sure the list will grow.
This started as a place to write useful tricks with linux, mainly on the command line. Now lets just say it's another random tech blog.
Wednesday, November 27, 2013
Monday, September 16, 2013
Using a Raspberry Pi as a media server
Just got a Raspberry Pi. Pretty sweet. So far I like it.
I've had this post as a draft for quite a while, planning to make some great interesting post, but I've run into quite a bit of trouble trying to find a reliable setup that I liked, and that worked.
Here's what I've got that works ok so far:
First off. I don't have that big of an sd card(which is like the hard drive) for my pi. and all of my music is on my desktop computer. First thing I do is use sshfs to gain access to my music.
$sshfs desktop:Music/ Music/
I use public/private rsa keys to connect so I don't need a password. I also have the desktop computer's ip defined in my /etc/hosts file. For any help check here.
Now that I have access to my music, my most used tool is cmus. It is a music player that supports a music library, has vi like commands, and runs inside a terminal. There are others out there, the first I tried was MOC, but after trying cmus I switched.
After logging into my pi via ssh. I run tmux.(more info about tmux here.), then run cmus, find the music I want to listen to, start playing, then detach tmux, and I can then exit ssh.
Another option. If you wanted to control your music from say... your phone. Then I would use:
$vlc -I http ~/Music/
This will run vlc as an http service, the the Music/ folder as the main library. I was using this but I have a large music library, and it was hard to navigate very well. If you specified the folder with all the music you would like to listen to I think this would probably work better.
Currently working on running the nuvola music player, then using nuvolaplayer-client to control it from another computer. If I get it working I will definitely update.
=================
UPDATE: I just installed OpenELEC on my raspberry pi (It runs xbmc). It's easy to set up. I would recommend this method if you are going to be using it for different types of media.
I've had this post as a draft for quite a while, planning to make some great interesting post, but I've run into quite a bit of trouble trying to find a reliable setup that I liked, and that worked.
Here's what I've got that works ok so far:
First off. I don't have that big of an sd card(which is like the hard drive) for my pi. and all of my music is on my desktop computer. First thing I do is use sshfs to gain access to my music.
$sshfs desktop:Music/ Music/
I use public/private rsa keys to connect so I don't need a password. I also have the desktop computer's ip defined in my /etc/hosts file. For any help check here.
Now that I have access to my music, my most used tool is cmus. It is a music player that supports a music library, has vi like commands, and runs inside a terminal. There are others out there, the first I tried was MOC, but after trying cmus I switched.
After logging into my pi via ssh. I run tmux.(more info about tmux here.), then run cmus, find the music I want to listen to, start playing, then detach tmux, and I can then exit ssh.
Another option. If you wanted to control your music from say... your phone. Then I would use:
$vlc -I http ~/Music/
This will run vlc as an http service, the the Music/ folder as the main library. I was using this but I have a large music library, and it was hard to navigate very well. If you specified the folder with all the music you would like to listen to I think this would probably work better.
Currently working on running the nuvola music player, then using nuvolaplayer-client to control it from another computer. If I get it working I will definitely update.
=================
UPDATE: I just installed OpenELEC on my raspberry pi (It runs xbmc). It's easy to set up. I would recommend this method if you are going to be using it for different types of media.
Shell history search
Found at http://lifehacker.com/supercharge-your-command-lines-history-search-with-fou-478683529
I have found this to be very useful.
create file ~/.inputrc and add these lines:
"\e[A": history-search-backward
"\e[B": history-search-forward
set show-all-if-ambiguous on
set completion-ignore-case on
This will make it so that when you use the up arrow to go through your search history, if you have anything already typed, it will only search anything with that term. e.g. if you want to run a sudo command from before you can type sudo, then use the up arrow to search commands that were run with sudo.
I have found this to be very useful.
create file ~/.inputrc and add these lines:
"\e[A": history-search-backward
"\e[B": history-search-forward
set show-all-if-ambiguous on
set completion-ignore-case on
This will make it so that when you use the up arrow to go through your search history, if you have anything already typed, it will only search anything with that term. e.g. if you want to run a sudo command from before you can type sudo, then use the up arrow to search commands that were run with sudo.
Monday, September 2, 2013
Using your ssh config file to connect to a computer through a gateway.
At my school I have some public IP addresses and virtual machines for them to use for class projects. I enjoy connecting from home but I have to go through the school's ssh server to connect to a vm(virtual maching). Having to hop through the school's server every single time I want to connect can be cumbersome, and also makes it more difficult to send files to my vm, since I have to send the file to the ssh server, then connect to it and send it again to the vm.
The other day I started looking for a way to modify my ~/.ssh/config file to have it automatically go to the vm. I tried a few different things. Some didn't work and some weren't working because of a mistake of my own. Finally I found how to make it work. My config file is set up like so:
Host school
HostName domain.name.of.school.ssh.server
User my_school_username
Host ns1
HostName <ip of my master nameserver>
ProxyCommand ssh school -W %h:%p
Host ns2
HostName <ip of slave nameserver>
ProxyCommand ssh school -W %h:%p
The computers ns1 and ns2 are the ones that are behind the school's ssh server, and school I set as the ssh server. the ProxyCommand lines let ssh know that every time I want to connect to ns1 or ns2 that I need to go through 'school'.
One problem I ran into was that I tried to use the HostName ns1 or ns2(since they are designated as such in the ssh config on the school server). That doesn't work. You have to put in the ip of the machine.
The other day I started looking for a way to modify my ~/.ssh/config file to have it automatically go to the vm. I tried a few different things. Some didn't work and some weren't working because of a mistake of my own. Finally I found how to make it work. My config file is set up like so:
Host school
HostName domain.name.of.school.ssh.server
User my_school_username
Host ns1
HostName <ip of my master nameserver>
ProxyCommand ssh school -W %h:%p
Host ns2
HostName <ip of slave nameserver>
ProxyCommand ssh school -W %h:%p
The computers ns1 and ns2 are the ones that are behind the school's ssh server, and school I set as the ssh server. the ProxyCommand lines let ssh know that every time I want to connect to ns1 or ns2 that I need to go through 'school'.
One problem I ran into was that I tried to use the HostName ns1 or ns2(since they are designated as such in the ssh config on the school server). That doesn't work. You have to put in the ip of the machine.
Enabling the right click on an hp pavilion dm4 with ubuntu 12.04
I have a 14" HP Pavilion dm4 laptop and like most of my laptops, the mousepad always seems to have some type of problem at the beginning. On the dm4 my problem was that the right click didn't work. after finding an askubuntu.com question about it I found that I needed to run these three commands.
synclient RightButtonAreaRight=1
synclient RightButtonAreaBottom=1
synclient AreaBottomEdge=3500
synclient RightButtonAreaRight=1
synclient RightButtonAreaBottom=1
synclient AreaBottomEdge=3500
Sadly, I can not expound really on what the synclient command does, I just know that I needed to run all three before it would work and I have to run them each time I reboot (I'll try and figure out how have it stick even after rebooting and edit this post when I do.)
Send a message to another computer via ssh
I don't know if everyone else has the same problem as me, but I have two computers in different rooms, and sometimes my wife and I are on each computer. Sometimes I want to tell my wife something or send her a message, but I'm just too lazy to get up and go into the other room to talk to her. One thing I do have is ssh access to all of my computers. After searching a little (there's references to this just about everywhere), I found how to send a message to my wife via ssh.
ssh
export DISPLAY=:0
notify-send "Message"
Now I had a computer before that for some reason or another, the default monitor/display wasn't 0 and it took some searching to find out which was the right one. Although the easiest way would probably be to increment the display number until you find the right one.
notify-send will send a notification to the screen which will time out and can easily be missed if the person on the other computer is not watching. You can also put a message in a text file, then open it up with something like gvim textfile.txt which will open a new window with the text file (gvim can also be replaced with the more common gedit)
Once you export the display in fact, you can open up any graphical program, and it will open up on that computer.
If you open up a program and then want to close after, you can run
killall <program_name>
to close it.
ssh
export DISPLAY=:0
notify-send "Message"
Now I had a computer before that for some reason or another, the default monitor/display wasn't 0 and it took some searching to find out which was the right one. Although the easiest way would probably be to increment the display number until you find the right one.
notify-send will send a notification to the screen which will time out and can easily be missed if the person on the other computer is not watching. You can also put a message in a text file, then open it up with something like gvim textfile.txt which will open a new window with the text file (gvim can also be replaced with the more common gedit)
Once you export the display in fact, you can open up any graphical program, and it will open up on that computer.
If you open up a program and then want to close after, you can run
killall <program_name>
to close it.
Sunday, August 25, 2013
Using sshfs to set up a filesystem via ssh
I stumbled upon this because I wanted to use my Raspberry Pi as a media device. (There'll be a great post on some ways to do that but I haven't figured out how I want to do it and gotten it to work yet.) Basically, my raspberry pi doesn't have enough room for all of my media. (mainly just music is all I was working with) and all of my music is on another computer on the network. I tried setting up an ftp server on that computer, which will work, I just didn't like it very much. Eventually I found sshfs which was great for what I wanted to do.
To install sshfs if you don't already have it. - on ubuntu/similar.
sudo apt-get install sshfs
If you have used ssh or scp then sshfs should be pretty simple It's set up like this:
sshfs [user@]host:[dir] mountpoint [options]
So, lets say I'm logged into my raspberry pi, and I want, let's say to be able to access all of my music from my desktop computer through a folder in my home directory(on my raspberry pi). My desktop is named sigsauer.
From my raspberry pi:
mkdir ~/Music/
(if it doesn't already exist)
then,
sshfs sigsauer:Music/ ~/Music/
One thing I learned at this point, is that when you install new system you need to remember to keep you /etc/hosts file up-to-date. Because if you don't you might run into problems when trying to use the computer name. Once I got past that little hangup, then things started to work perfectly.
Now I could go into my Music folder which I just created and access all of the files as if they were local.
This has been great for me since I have 2 computers and a raspberry pi, that stay at home and are always on the same network, I don't like having my music library all over the place, adding music here and there then making a mess when I try to compile it. Now I have everything reading off and editing the same library, making it much easier to keep my library organized.
One of the computers has ubuntu server on it and I didn't feel like dealing with installing dropbox on it, so I simply added a command to my crontab to mount the dropbox folder from my desktop computer to my server computer. More about crontab here.
Keep in mind that to add it to the crontab, since it can't ask you for a password you need to have passwordless ssh authentication. I have a little bit of instruction about how to do that which I may have to turn into a new post, but I found the easiest way for me is to simply copy the whole ~/.ssh/ folder from one computer to the other, then delete any offending keys from ~/.ssh/known_hosts file.
Once you are done with sshfs and don't need access to the files anymore, you can unmount the directory by simply:
fusermount -u <mount_point>
so to unmount my Music -
fusermount -u ~/Music/
And now if you went into the folder it should be empty.
To install sshfs if you don't already have it. - on ubuntu/similar.
sudo apt-get install sshfs
If you have used ssh or scp then sshfs should be pretty simple It's set up like this:
sshfs [user@]host:[dir] mountpoint [options]
So, lets say I'm logged into my raspberry pi, and I want, let's say to be able to access all of my music from my desktop computer through a folder in my home directory(on my raspberry pi). My desktop is named sigsauer.
From my raspberry pi:
mkdir ~/Music/
(if it doesn't already exist)
then,
sshfs sigsauer:Music/ ~/Music/
One thing I learned at this point, is that when you install new system you need to remember to keep you /etc/hosts file up-to-date. Because if you don't you might run into problems when trying to use the computer name. Once I got past that little hangup, then things started to work perfectly.
Now I could go into my Music folder which I just created and access all of the files as if they were local.
This has been great for me since I have 2 computers and a raspberry pi, that stay at home and are always on the same network, I don't like having my music library all over the place, adding music here and there then making a mess when I try to compile it. Now I have everything reading off and editing the same library, making it much easier to keep my library organized.
One of the computers has ubuntu server on it and I didn't feel like dealing with installing dropbox on it, so I simply added a command to my crontab to mount the dropbox folder from my desktop computer to my server computer. More about crontab here.
Keep in mind that to add it to the crontab, since it can't ask you for a password you need to have passwordless ssh authentication. I have a little bit of instruction about how to do that which I may have to turn into a new post, but I found the easiest way for me is to simply copy the whole ~/.ssh/ folder from one computer to the other, then delete any offending keys from ~/.ssh/known_hosts file.
Once you are done with sshfs and don't need access to the files anymore, you can unmount the directory by simply:
fusermount -u <mount_point>
so to unmount my Music -
fusermount -u ~/Music/
And now if you went into the folder it should be empty.
Subscribe to:
Posts (Atom)