开发环境的搭建主要有网络设置(静态IP,SSH,SMB,NFS),编译环境(编译器,SDK)2部分。在做这2件事之前先要更新apt-get install update或者直接在网上
找到对应版本的sources.list ,然后打开etc/apt/sources.list 更新里面的内容。这个一定要先做,不然后面安装的SSH等服务有可能因版本问题无法启动。
1.静态IP的配置
a.在虚拟机里一定要注意网卡的配置。一般设置成桥接,如果PC与虚拟机相互都ping不通,八成是虚拟机网卡有问题,检查网卡是都连接了。或者删除了重新添加个网卡。
这个一般在虚拟机 VM/SETTING下设置
b.临时设置IP用ifconfig eth0 192.168.1.18即可,然后就可以通过ping测试了,一定要相互ping通。
c.如果想每次开机都是静地址 则在 /etc/network/interfaces
auto eth0
iface eth0 inet static
address 192.168.1.5
netmask 255.255.255.0
gateway 192.168.1.1
d.设置DNS
如果是手动指定IP并且还需要访问互联网,那么还需要设置DNS:
$sudo gedit /etc/resolv.conf
假如dns地址为61.177.7.1,则向这里添加如下配置内容:
nameserver 61.177.7.1
保存即可。
重启网络组件让网络配置文件生效:
$sudo /etc/init.d/networking restart
只要显示Reconfiguring network interfaces... [OK]
即成功重启网络组件。
2.ssh 服务安装及启动
安装 XSH
网上有很多介绍在Ubuntu下开启SSH服务的文章,但大多数介绍的方法测试后都不太理想,均不能实现远程登录到Ubuntu上,最后分析原因是都没有真正开启ssh-server服务。最终成功的方法如下:
Ubuntu 下安装 OpenSSH Server 是无比轻松的一件事情,需要的命令只有一条:
sudo apt-get install openssh-server
(查看返回的结果,如果没有出错,则用putty、SecureCRT、SSH Secure Shell Client等SSH 客户端软件,输入您服务器的 IP 地址。如果一切正常的话,等一会儿就可以连接上了。并且使用现有的用户名和密码应该就可以登录了。)
然后确认sshserver是否启动了:(或用“netstat -tlp”命令)
ps -e | grep ssh
如果只有ssh-agent那ssh-server还没有启动,需要/etc/init.d/ssh start,如果看到sshd那说明ssh-server已经启动了。
ssh-server配置文件位于/ etc/ssh/sshd_config,在这里可以定义SSH的服务端口,默认端口是22,你可以自己定义成其他端口号,如222。然后重启SSH服务:
sudo /etc/init.d/ssh resart
事实上如果没什么特别需求,到这里 OpenSSH Server 就算安装好了。但是进一步设置一下,可以让 OpenSSH 登录时间更短,并且更加安全。这一切都是通过修改 openssh 的配置文件 sshd_config 实现的。
首先,您刚才实验远程登录的时候可能会发现,在输入完用户名后需要等很长一段时间才会提示输入密码。其实这是由于 sshd 需要反查客户端的 dns 信息导致的。我们可以通过禁用这个特性来大幅提高登录的速度。首先,打开 sshd_config 文件:
sudo nano /etc/ssh/sshd_config
找到 GSSAPI options 这一节,将下面两行注释掉:
#GSSAPIAuthentication yes #GSSAPIDelegateCredentials no然后重新启动 ssh 服务即可:
sudo /etc/init.d/ssh restart
再登录试试,应该非常快了吧
利用 PuTTy 通过证书认证登录服务器
SSH 服务中,所有的内容都是加密传输的,安全性基本有保证。但是如果能使用证书认证的话,安全性将会更上一层楼,而且经过一定的设置,还能实现证书认证自动登录的效果。
首先修改 sshd_config 文件,开启证书认证选项:
RSAAuthentication yes PubkeyAuthentication yes AuthorizedKeysFile %h/.ssh/authorized_keys修改完成后重新启动 ssh 服务。
下一步我们需要为 SSH 用户建立私钥和公钥。首先要登录到需要建立密钥的账户下,这里注意退出 root 用户,需要的话用 su 命令切换到其它用户下。然后运行:
ssh-keygen
这里,我们将生成的 key 存放在默认目录下即可。建立的过程中会提示输入 passphrase,这相当于给证书加个密码,也是提高安全性的措施,这样即使证书不小心被人拷走也不怕了。当然如果这个留空的话,后面即可实现 PuTTy 通过证书认证的自动登录。
ssh-keygen 命令会生成两个密钥,首先我们需要将公钥改名留在服务器上:
cd ~/.ssh mv id_rsa.pub authorized_keys然后将私钥 id_rsa 从服务器上复制出来,并删除掉服务器上的 id_rsa 文件。
服务器上的设置就做完了,下面的步骤需要在客户端电脑上来做。首先,我们需要将 id_rsa 文件转化为 PuTTy 支持的格式。这里我们需要利用 PuTTyGEN 这个工具:
点击 PuTTyGen 界面中的 Load 按钮,选择 id_rsa 文件,输入 passphrase(如果有的话),然后再点击 Save PrivateKey 按钮,这样 PuTTy 接受的私钥就做好了。
打开 PuTTy,在 Session 中输入服务器的 IP 地址,在 Connection->SSH->Auth 下点击 Browse 按钮,选择刚才生成好的私钥。然后回到 Connection 选项,在 Auto-login username 中输入证书所属的用户名。回到 Session 选项卡,输入个名字点 Save 保存下这个 Session。点击底部的 Open 应该就可以通过证书认证登录到服务器了。如果有 passphrase 的话,登录过程中会要求输入 passphrase,否则将会直接登录到服务器上,非常的方便。
ELL即可
3. SMB服务开启
smb服务器的启动,停止,重启
/etc/init.d/smbd stop
/etc/init.d/smbd start
/etc/init.d/smbd restart
另一种方法service smbd restart
建公用共享文件夹
如果允许访问此共享文件夹的用户可以操作(修改)它,需要chmod 777 共享文件夹
[public]
comment = public
path = /home/skyli/public
guest ok = yes
browseable = yes
create mask = 0644
directory mask = 0755
writable = yes
.建立只有smb帐号才能访问的共享文件夹
[docs]
comment = docs
path = /home/skyli/docs
guest ok = no
browseable = yes
create mask = 0644
directory mask = 0755
writable = yes
.添加,删除smb用户
smbpasswd -a username
smbpasswd -x username
像使用ftp一样登录到共享文件夹
smbclient //192.168.1.170/public -U username
如果要查看当前smb服务器有哪些共享文件夹,加"-L",即smbclient -L //192.168.1.170/public -U username
这里的public是你smb服务器上共享文件夹的名字,直接写共享文件夹名字,不能写共享文件夹的绝对路径(如果写就连接不上).
测试时发现,如果public是匿名访问的公用文件,通过smbclient //192.168.1.170/public -U username访问时,username可以随便输入个帐号,密码也可以随便输入即可访问.
将共享文件挂载到本地
sudo smbmount //192.168.1.170/public /mnt/public -o iocharset=utf8,uid=skyli,gid=skyli,username=xfli
查看当前所有挂载点,卸载挂载点
查看mount -l
卸载umount /mnt/public
打印机共享
安装Samba
安装samba
sudo apt-get install samba
配置
第一步创建共享目录: 比如要创建/home/用户名/share首先创建这个文件夹 (这个用户名就是你的用户名,为了方便易懂我才这样写的,到时记得自己改啊)
代码:
mkdir /home/用户名/share (新建share文件夹)
chmod 777 /home/用户名/share (设置该文件夹的权限使其让所有用户可读可写可运行)
备份并编辑smb.conf允许网络用户访问 (养成随时备份的好习惯,在关键的时候你会发现当初的备份是多么的明智!) 代码:
sudo cp /etc/samba/smb.conf /etc/samba/smb.conf_backup
sudo gedit /etc/samba/smb.conf
搜寻这一行文字 代码:
; security = user
用下面这几行取代
代码:
security = user
username map = /etc/samba/smbusers
将下列几行新增到文件的最后面,假设允许访问的用户为:new。而文件夹的共享名为Share #这里之所以这么写就是因为后面我们要创建一个smb用户new,并且让XP用户通过这个new来和我们进行数据交流。当然你可以写为自己喜欢的名字 只不过前后要一致就可以了
代码:
[Share]
comment = Shared Folder with username and password
path = /home/用户名/share
public = yes
writable = yes
valid users = new
create mask = 0700
directory mask = 0700
force user = nobody #用于指定创建文件的所有者用户,这样其它系统对共享目录的操作相当于该指定用户的所做的操作
force group = nogroup #用于指定创建文件的所有者组(注意要确保这个组名是存在的,否则会出错,连接不上)
available = yes
browseable = yes
然后顺便把这里改一下,找到[global]把workgroup = MSHOME 改成:(注意,这里的WORKGROUP是共享中的工作组名称) 代码:
workgroup = WORKGROUP
display charset = UTF-8
unix charset = UTF-8
dos charset = cp936
后面的三行是为了防止出现中文目录乱码的情况。 现在要添加new这个网络访问帐户。如果系统中当前没有这个帐户,那么
代码:
sudo useradd new
要注意,上面只是增加了new这个用户,却没有给用户赋予本机登录密码。所以这个用户将只能从远程访问,不能从本机登录。而且samba的登录密码可以和本机登录密码不一样。现在要新增网络使用者的帐号:
代码:
sudo smbpasswd -a new (设置你的new密码,这个密码不是开机登录时候用的,是你要访问WIN共享文件或者WIN共享文件访问你的时候要填的密码)sudo gedit /etc/samba/smbusers
在新建立的文件内加入下面这一行并保存
代码:
new = “network username”
如果将来需要更改new的网络访问密码,也用这个命令更改
代码:
sudo smbpasswd -a new
删除网络使用者的帐号的命令把上面的-a 改成-x sudo smbpasswd -x new
测试并重启samba
代码:
sudo testparm
sudo /etc/init.d/samba restart
UNIX系统远程访问
sudo mount -t cifs -o uid=用户名,user=samba用户名,password=samba用户密码,file_mode=0777,dir_mode=0777 //10.41.0.102/Share /var/www/TcWebFile
Windows系统远程访问
\\服务器IP地址
摘自 踏雪无痕
4.nfs 服务开启
建立 nfs 服务器
在嵌入式 linux 开发的时候,常常需要使用 nfs 以方便程序的调试。使用 nfs,用户可以
将板子要用到的根文件系统放在主机目录下,开发板则通过以太网挂载到这个目录并将这个
目录下的文件作为根文件系统的内容,这样用户的程序更新后不比重新烧写板子的根文件系
统便能被重新使用,这点能够大大加快程序的调试。
Ubuntu 下安装 nfs 服务器的步骤如下:
4.3.1 进行 NFS 服务器端与客户端的安装:
sudo apt-get install nfs-kernel-server nfs-common portmap
安装客户端的作用是可以在本机进行 NFS 服务的测试。
4.3.2 配置 portmap
两种方法任选一种就可以:
(1):sudo emacs /etc/default/portmap
去掉 -i 127.0.0.1
(2)sudo dpkg-reconfigure portmap
运行后选择“否”
另外很重要的一点,要用 sysv-rc-conf (而不是 chkconfig)工具查看一下当前 nfs 和 portmap
的状态,若是 off,则用 sudo sysv-rc-conf portmap on 或 sudo sysv-rc-conf nfs-kernel-server on
打开
4.3.3 配置挂载目录和权限
emacs /etc/exports
我的配置如下:
# /etc/exports: the access control list for filesystems which may be exported
# to NFS clients. See exports(5).
#
# Example for NFSv2 and NFSv3:
# /srv/homes hostname1(rw,sync) hostname2(ro,sync)
#
# Example for NFSv4:
# /srv/nfs4 gss/krb5i(rw,sync,fsid=0,crossmnt)
# /srv/nfs4/homes gss/krb5i(rw,sync)
#
/nfsboot *(rw,sync)
解释一下:
#后面的都是解释
/nfsboot 是 NFS 的共享目录,*表示任何 IP 都可以共享这个目录,你可以改为受限的 IP,rw
表示的是权限,sync 是默认的。
4.3.4 更新 exports 文件
只要你更改了/etc/exports, 你不可以通过 sudo exportfs -r 来更新 这个文件
4.3.5 重启 NFS 服务
Sudo /etc/init.d/portmap start
sudo /etc/init.d/nfs-kernel-server restart 重启 nfs 服务
4.3.6 进行测试
尝试一下挂载本地磁盘(我的 linux 系统 IP 为 202.198.137.18,将/home/nfsboot 挂载到/mnt)
$ sudo mount 202.198.137.18:/nfsboot /mnt
运行 $ df 看看结果
$ sudo umount /mnt
5.设置根用户
为root设置密码,在终端执行“sudo passwd root” 指令后,系统会提示你设置一个root账号的密码。在你没有经过当前用户密码验证的时候,还会要求你先输入当前用户的密码,然后才能设置root帐号的密码。设置完成后,就可以在终端切换到root用户了。
5.nfs
===