ubuntu 安装及开发环境搭建需注意的问题

       开发环境的搭建主要有网络设置(静态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

 

===

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值