内容简介:用基于浏览器(webdriver)的selenium技术爬取数据,所以程序需运行在GUI环境下。本文分三个部分简要介绍安装GUI界面及远程连接的步骤。大多数云服务器厂商提供的镜像都无GUI界面,所以要先安装图形环境。本文使用GNOME桌面环境:
用基于浏览器(webdriver)的selenium技术爬取数据,所以程序需运行在GUI环境下。本文分三个部分简要介绍安装GUI界面及远程连接的步骤。
安装GUI界面
大多数云服务器厂商提供的镜像都无GUI界面,所以要先安装图形环境。本文使用GNOME桌面环境:
yum -y groups install "GNOME Desktop"
这条命令将安装GNOME桌面的必要软件包,执行完后配置X系统使用GNOME:
echo "exec gnome-session" >> ~/.xinitrc
安装KDE或者MATE桌面环境的两个命令稍微不一样:
# kde yum -y groups install "KDE Plasma Workspaces" echo "exec startkde" >> ~/.xinitrc # mate yum --enablerepo=epel -y groups install "MATE Desktop" echo "exec /usr/bin/mate-session" >> ~/.xinitrc
以上便安装好了GUI桌面环境。
启动桌面环境有两种方式:
startx systemctl set-default graphical.target
安装vnc-server
有了桌面环境,一般可以通过云服务器厂商提供的web终端远程连接进入桌面。用web终端每次都需要打开浏览器,然后登陆云管理后台再连接,比较麻烦。我们采取直接从桌面客户端远程连接的方式,省去打开浏览器和登录云管理后台的操作。
远程桌面技术有多种,例如VNC, TeamViewer, RDP等,本文使用免费且广泛使用的VNC。
在服务器上先安装服务端(tigervnc是tightvnc的分支):
yum install -y tigervnc-server
接着复制一份VNC配置:
cp /lib/systemd/system/[email protected] /etc/systemd/system/[email protected]:1.service
注意上述命令参数重的“@:1”,可以将 数字1换成30000内的任意数字
,“5900+数字”即为程序的显示(监听)端口,如”@:1″表示监听5901端口。
编辑该配置文件,将文件内的 <USER>
替换成远程连接时的登录用户名(如果是root,注意将第二个 <USER>
所在行的”/home”移除掉)。以root身份的配置示例:
# The vncserver service unit file # # Quick HowTo: # 1. Copy this file to /etc/systemd/system/<a href="/cdn-cgi/l/email-protection" data-cfemail="95e3fbf6e6f0e7e3f0e7d5bbe6f0e7e3fcf6f0">[email protected]</a> # 2. Replace <USER> with the actual user name and edit vncserver # parameters appropriately # (ExecStart=/usr/sbin/runuser -l <USER> -c "/usr/bin/vncserver %i" # PIDFile=/home/<USER>/.vnc/%H%i.pid) # 3. Run `systemctl daemon-reload` # 4. Run `systemctl enable <a href="/cdn-cgi/l/email-protection" data-cfemail="51273f3222342327342311">[email protected]</a>:<display>.service` # # DO NOT RUN THIS SERVICE if your local area network is # untrusted! For a secure way of using VNC, you should # limit connections to the local host and then tunnel from # the machine you want to view VNC on (host A) to the machine # whose VNC output you want to view (host B) # # [<a href="/cdn-cgi/l/email-protection" data-cfemail="b0c5c3d5c2f0d8dfc3c4f1">[email protected]</a> ~]$ ssh -v -C -L 590N:localhost:590M hostB # # this will open a connection on port 590N of your hostA to hostB's port 590M # (in fact, it ssh-connects to hostB and then connects to localhost (on hostB). # See the ssh man page for details on port forwarding) # # You can then point a VNC client on hostA at vncdisplay N of localhost and with # the help of ssh, you end up seeing what hostB makes available on port 590M # # Use "-nolisten tcp" to prevent X connections to your VNC server via TCP. # # Use "-localhost" to prevent remote VNC clients connecting except when # doing so through a secure tunnel. See the "-via" option in the # `man vncviewer' manual page. [Unit] Description=Remote desktop service (VNC) After=syslog.target network.target [Service] Type=forking # Clean any existing files in /tmp/.X11-unix environment ExecStartPre=/bin/sh -c '/usr/bin/vncserver -kill %i > /dev/null 2>&1 || :' ExecStart=/usr/sbin/runuser -l root -c "/usr/bin/vncserver %i" PIDFile=/root/.vnc/%H%i.pid ExecStop=/bin/sh -c '/usr/bin/vncserver -kill %i > /dev/null 2>&1 || :' [Install] WantedBy=multi-user.target
接下来设置 vnc连接密码
:
vncpasswd
注意连接密码与 登录密码
不同:连接密码用于显示远程桌面,登录密码用于用户登录系统。
设置好后,启动vnc服务:
systemctl daemon-reload systemctl start <a href="/cdn-cgi/l/email-protection" data-cfemail="dfa9b1bcacbaada9baad9f">[email protected]</a>:1 systemctl enable <a href="/cdn-cgi/l/email-protection" data-cfemail="e2948c81918790948790a2">[email protected]</a>:1
如果开启了防火墙,注意放行相应端口。
客户端连接
服务端配置完毕,接下来用客户端连接。
vnc是免费技术,许多客户端都支持该协议。本文采用App Store上免费的“Remote Desktop – VNC”软件进行连接,打开后软件界面如下:
在输入框填写服务器地址:vnc://ip:port,其中ip是服务器的ip或域名,port是监听的端口,例如5901。输入后按回车,弹出密码输入框,输入 vncpasswd
设置的密码。密码正确的话就可以看到服务器的图形桌面,例如:
按回车键进入登录界面,输入 登录
用户名和密码进入系统:
接下来就可以做各种图形操作了。
参考
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 几个连接HiveServer的客户端界面工具
- 几个连接HiveServer的客户端界面工具
- CentOS 图形界面和字符界面切换
- GUI 界面如何设计?
- 小程序新请假界面
- webflux 用户管理界面
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。