【Linux】【开发环境】【RHEL】开发环境搭建系列之一——安装Virtual Box虚拟机搭建基础嵌入式开发环境

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 【Linux】【开发环境】【RHEL】开发环境搭建系列之一——安装Virtual Box虚拟机搭建基础嵌入式开发环境

前言


Linux环境搭建


嵌入式开发或学习过程中,经常需要涉及Linux开发环境的搭建。生产环境下,一般都是直接在配置较高的服务器上安装。而对于个人学习而言,没有现成的服务器,无非两个选择:


  • 双系统:经常需要修改启动项,如操作失误,可能会导致windows无法启动;


  • 虚拟机:使用虚拟机的方式,在主机上虚拟另外一台主机。


本文主要讲解虚拟机VB安装RHEL并将网络接口、IP、DNS、FTP、SAMBA等配置完成的过程。


虚拟机软件选择


常用虚拟机软件大概有下面几种:


  • Vmware Workstation


  • Virtual Box


  • Windows Virtual PC


  • VMware Player


比较常用的是Virtual Box和Vmware Workstation两个软件,但Vmware Workstation是收费的,Virtual Box是免费的,本文主要以Virtual Box 6.16为例来说明具体的操作过程。


Linux发布版本


一般来说著名的linux发布版本基本上分两大阵营:


  • RedHat系列:Redhat、Centos、Fedora等;


  • Debian系列:Debian、Ubuntu等;


RedHat主要集中在企业级服务器版的制作 是推动Linux商业化最成功的公司 RedHat对应的桌面版制作都是由Fedora社区研发。


RHEL是Red Hat的企业版。


Ubuntu桌面版适合初学者使用比较简单,桌面用户的首选ubuntu 。


本文选择RHEL7,因为比较适合企业级别使用。


具体操作


1、VirtualBox安装RHEL


这个流程可参考后文参考资料【1】【2】,比较详细,不再赘述;


这里主要注意几点:


  • VB的网络模式建议配置为桥接模式,这样,虚拟机和主机会在一个网段中,方便虚拟机上网并和主机交换数据。


  • LOCALIZATION:DATA&TIME选下时区、LANGUAGE SUPPORT选下汉语;


  • SOFTWARE:选“Server with GUI”,千万不要选“Minimal Install”,同时在右边软件列表中,尽量将会用到的软件或服务选中。


  • SYSTEM:“NETWORK&HOSTNAME”,主要把网络配置下。


经过上述操作,不出意外,RHEL已经拿到IP地址,后续可以使用ssh连接RHEL了,不需要在VB界面里操作了。


2、IP地址


上一步如果选择DHCP方式,则默认会在ifcfg-enp0s3文件中写下面的内容:


[qxhgd@localhost /]$ cat ./etc/sysconfig/network-scripts/ifcfg-enp0s3
TYPE="Ethernet"
PROXY_METHOD="none"
BROWSER_ONLY="no"
BOOTPROTO="dhcp"
DEFROUTE="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
IPV6_ADDR_GEN_MODE="stable-privacy"
NAME="enp0s3"
UUID="e26ca312-25e6-45de-8a15-7bb03df1ff37"
DEVICE="enp0s3"
ONBOOT="yes"


2.1、重命名接口


这里默认的网卡名为enp0s3,不是通常的eth0,可以通过下面方式修改:


  • 配置文件调整,将其中的NAME和DEVICE都修改为eth0


[qxhgd@localhost]$ mv ifcfg-enp0s3 ifcfg-eth0


  • 禁用网卡命名规则并生成新的grub配置参数


修改grub引导文件,在GRUB_CMDLINE_LINUX中增加net.ifnames=0 biosdevname=0部分,并使用grub2-mkconfig命令更新grub配置参数


[qxhgd@localhost ~]$ vi /etc/sysconfig/grub
GRUB_TIMEOUT=5
GRUB_DISTRIBUTOR="$(sed 's, release .*$,,g' /etc/system-release)"
GRUB_DEFAULT=saved
GRUB_DISABLE_SUBMENU=true
GRUB_TERMINAL_OUTPUT="console"
GRUB_CMDLINE_LINUX="crashkernel=auto spectre_v2=retpoline rd.lvm.lv=rhel/root rd.lvm.lv=rhel/swap net.ifnames=0 biosdevname=0 rhgb quiet"
GRUB_DISABLE_RECOVERY="true"


[qxhgd@localhost ~]$ grub2-mkconfig -o /boot/grub2/grub.cfg


  • 重启虚拟机


2.2、配置固定IP


修改配置文件中的IP地址、掩码、网关、以及获取地址方式等几个字段即可。


[qxhgd@localhost ~]$ cat /etc/sysconfig/network-scripts/ifcfg-eth0
BOOTPROTO="static"
IPADDR=192.168.2.100
NETMASK=255.255.255.0
GATEWAY=192.168.2.1
ONBOOT=yes 


经过上述操作后,已经可以在主机上使用putty软件通过SSH访问RHEL的IP了。


3、DNS服务器


如果前两步网络配置的有问题,或者不是DHCP方式获取地址,可能没有生成DNS服务器,则此时可通过下面这个文件进行修改;


[qxhgd@localhost ~]$cat /etc/resolv.conf
# Generated by NetworkManager
nameserver 192.168.2.1


DNS如果不在这个文件配置,在ifcfg-eth0文件中修改也可以:


[qxhgd@localhost ~]$cat /etc/sysconfig/network-scripts/ifcfg-eth0
DNS1=192.168.2.1      //网卡eth0的第一个DNS服务器                                                  
DNS2=8.8.8.8          //网卡eth0的第二个DNS服务器    


4、SAMBA服务


4.1 账户添加到smaba协议


[qxhgd@localhost ~]$ sudo smbpasswd -a qxhgd
[sudo] password for qxhgd
New SMB password:
Retype new SMB password:
Added user qxhgd
[qxhgd@localhost ~]$ 


4.2 配置账户的权限目录


[qxhgd@localhost ~]$ setfacl -m u:qxhgd:rw /home/qxhgd


不建议使用chmod修改目录权限,不安全。


4.3 修改samba的配置文件


[qxhgd@localhost ~]$ cat /etc/samba/smb.conf
[qxhgd]
        path = /home/qxhgd
        browseable=yes
        writeable=yes
        write list = qxhgd


4.4 启动smb服务


[qxhgd@localhost ~]$ systemctl start smb nmb
[qxhgd@localhost ~]$ systemctl enable smb nmb


类似的命令还有service smb restart。


如果需要配置开机自动启动,可执行下面命令:


chkconfig smb on


4.5 关闭防火墙


[qxhgd@localhost ~]$firewall-cmd --permanent --add-service=samba
[qxhgd@localhost ~]$firewall-cmd --permanent --add-service=rpc-bind 
[qxhgd@localhost ~]$firewall-cmd --permanent --add-service=mountd 
[qxhgd@localhost ~]$firewall-cmd --reload


4.6 关闭SELINUX


[qxhgd@localhost ~]$ cat /etc/sysconfig/selinux
SELINUX=disabled
[qxhgd@localhost ~]$ sudo setenforce 0


5、FTP服务


这里主要以vsftpd为例说明,实际上RHEL上有其他选择。


另外,ftp账户可以有本地用户、虚拟用户、匿名访问三种,这里只关心本地用户的情况。


5.1 修改配置文件


  • 在vsftpd.conf中增加下面几项即可:


[qxhgd@localhost ~]$ cat /etc/vsftpd/vsftpd.conf
local_root=/home/qxhgd
chroot_local_user=YES
userlist_deny=NO
allow_writeable_chroot=YES


  • 在user_list中增加本地账号:


[qxhgd@localhost ~]$ cat /etc/vsftpd/user_list
...
qxhgd


5.2 启动vsftpd服务


重启:


[qxhgd@localhost ~]$ service vsftpd restart


启动:


[qxhgd@localhost ~]$ service vsftpd start


开机启动vsftpd服务:


[qxhgd@localhost ~]$ systemctl enable vsftpd


5.3 查看vsftpd服务状态


本质上下面几条命令都类似:


[qxhgd@localhost ~]$systemctl status vsftpd
[qxhgd@localhost ~]$systemctl status vsftpd.service 
[qxhgd@localhost ~]$systemctl status vsftpd.service -l


5.4 SELinux控制


[qxhgd@localhost ~]$setsebool -P ftpd_full_access=on


5.5 iptables控制


[qxhgd@localhost ~]iptables -I IN_public_allow -p tcp -m tcp --dport 21 -m conntrack --ctstate NEW,UNTRACKED -j ACCEPT


如果安装的时候,防火墙默认打开了,则需要将ftp使用的21端口放开。


相关操作技巧


1、VB增强工具


管理——全局设定——扩展中可安装下载好的增强工具。


注:有的VB版本是“设备——安装增强功能”这个路径。


2、VB虚拟机备份


控制——工具——备份【系统快照】(S),可以将某一时刻的虚拟机备份。


3、RHEL操作细节


  • 在修改ftp、smb、dns等配置文件之前,最好备份一份;


  • 如果忘记备份了,可从下载的iso文件中捞一份。


参考资料


【1】VirtualBox安装RedHat7


【2】电脑安装Linux虚拟机图文教程


【3】VMWare虚拟机网络配置


【4】Virtual Box资源


【5】RHEL7资源:rhel-server-7.7-x86_64-dvd.iso,提取码:iy2b

相关文章
|
5月前
|
Oracle Java 关系型数据库
入职必会-开发环境搭建41-Linux软件安装-安装JDK
本文介绍了在Linux系统中下载和安装JDK
184 3
入职必会-开发环境搭建41-Linux软件安装-安装JDK
|
5月前
|
域名解析 网络协议 Linux
入职必会-开发环境搭建38-Linux常用操作-Linux设置IP
目前安装的Linux操作系统默认是动态获取IP地址,IP地址可能会发生变动,需要把IP地址设置为静态的。
入职必会-开发环境搭建38-Linux常用操作-Linux设置IP
|
4月前
|
Linux KVM 数据库
虚拟机数据恢复—Linux系统下误删除KVM虚拟机的数据恢复案例
虚拟机数据恢复环境: Linux操作系统服务器,EXT4文件系统。服务器中有数台KVM虚拟机。 虚拟机故障: KVM虚拟机被删除,需要恢复raw格式的磁盘文件。
虚拟机数据恢复—Linux系统下误删除KVM虚拟机的数据恢复案例
|
4月前
|
NoSQL Linux C语言
嵌入式GDB调试Linux C程序或交叉编译(开发板)
【8月更文挑战第24天】本文档介绍了如何在嵌入式环境下使用GDB调试Linux C程序及进行交叉编译。调试步骤包括:编译程序时加入`-g`选项以生成调试信息;启动GDB并加载程序;设置断点;运行程序至断点;单步执行代码;查看变量值;继续执行或退出GDB。对于交叉编译,需安装对应架构的交叉编译工具链,配置编译环境,使用工具链编译程序,并将程序传输到开发板进行调试。过程中可能遇到工具链不匹配等问题,需针对性解决。
118 3
|
5月前
|
网络协议 Linux 网络安全
入职必会-开发环境搭建39-Linux常用操作-Linux防火墙操作
在CentOS 7中,新引入了firewalld服务(防火墙),取代了CentOS 6之前的iptables服务(防火墙)。
入职必会-开发环境搭建39-Linux常用操作-Linux防火墙操作
|
4月前
|
机器学习/深度学习 Ubuntu Linux
【机器学习 Azure Machine Learning】使用Aure虚拟机搭建Jupyter notebook环境,为Machine Learning做准备(Ubuntu 18.04,Linux)
【机器学习 Azure Machine Learning】使用Aure虚拟机搭建Jupyter notebook环境,为Machine Learning做准备(Ubuntu 18.04,Linux)
|
5月前
|
Linux
入职必会-开发环境搭建37-Linux常用操作-Linux服务管理
系统启动以后一直存在且常驻内存没有界面的进程就是服务。Linux系统中的所有服务都保存在下列目录中:/usr/lib/systemd/system,进入该目录就能看到所有的服务。
入职必会-开发环境搭建37-Linux常用操作-Linux服务管理
|
5月前
|
应用服务中间件 Linux 网络安全
|
5月前
|
应用服务中间件 Linux 网络安全
|
5月前
|
缓存 监控 Linux
入职必会-开发环境搭建40-Linux常用操作-Linux进程管理
进程是正在执行的程序或命令。每个进程独立的,都有需要占用一定的系统资源。Linux系统中启动进程有两种方式:1.Linux操作系统启动的时自动启动的进程。2.用户在终端输入命令启动的进程。
入职必会-开发环境搭建40-Linux常用操作-Linux进程管理