百度云服务器(BCC)使用学习手记

缘起

由于工作所带来的数据处理方面的需求和兴趣,初步接触了linux、python、mysql等,也通过VMware虚拟机在个人华为笔记本上搭建了学习环境。然而在笔记本上用虚拟机,占用资源还是其次,每次启动实在麻烦,也不可能随时都带着笔记本,于是对云服务器产生了兴趣。碰巧看到百度最初级配置的云服务器价格109元/年,不知道是否划算,至少对比起来比同期的阿里云、腾讯元便宜,于是果断入手。反正也是为了学习瞎折腾,且试用一年再说。

个人笔记本电脑上虚拟机搭建的学习环境

初识

百度云服务器配置

CPU 内存 带宽 系统盘 系统 价格
1核 1G 1M 40G Ubuntu 16.04 LTS 109元/年

CPU信息

(base) snail@instance-t009xqlo:~$ cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c
1  Intel(R) Xeon(R) Gold 6148 CPU @ 2.40GHz

系统信息

(base) snail@instance-t009xqlo:~$ cat /etc/issue
Ubuntu 16.04.1 LTS \n \l

网速测试

(base) snail@instance-t009xqlo:~$ speedtest-cli
Retrieving speedtest.net configuration...
Retrieving speedtest.net server list...
Testing from CNISP-Union Technology (Beijing) Co. (106.12.61.246)...
Selecting best server based on latency...
Hosted by China Telecom ZheJiang Branch (Hangzhou) [124.16 km]: 16.828 ms
Testing download speed........................................
Download: 61.41 Mbit/s
Testing upload speed..................................................
Upload: 1.04 Mbit/s

百度云管理控制台

登陆百度云(https://cloud.baidu.com)后,便可以进入百度云的控制台,查看云服务器BCC实例信息,重启、停止实例,更改实例配置,重置系统等等。

PS:云服务器重置系统非常方便,最适合我这样瞎折腾的

云服务器BCC实例详情
云服务器BCC实例监控
百度云网页版VNC控制台

安装图形化界面

百度云服务器的Ubuntu系统是没有图形化界面的,安装很简单,在VNC控制台中执行命令apt-get -y install x-window-system-core gnome-core gdm安装gnome桌面环境后,执行命令startx即可启动图形化桌面效果。目前用处不大,略过。

putty使用SSH密钥登录实例

网页版的VNC控制台看看就好,用起来很不舒服,所以还是抓紧配置好putty。

  • 下载putty

  • 在百度云服务器控制台中创建密钥对,并下载至本地

  • 运行puttygen.exe,载入所下载的密钥文件,生成私钥文件并保存至本地

  • 运行putty.exe,在会话中输入百度云服务器实例的公网IP,并保存

  • 在连接-SSH-认证中,打开此前生成的私钥文件

  • 完成上述配置后,点击打开,即可通过putty远程连接百度云服务器实例

搭建

下面开始在百度云服务器BCC实例(以下简称“服务器”)中瞎折腾地搭建学习环境

在服务器中创建新用户

服务器在创建后初始用户为管理员root,但一直用root账号折腾似乎不太好,因此需要先创建一个新用户。

Ubuntu系统中创建新用户有两个命令:useraddadduser。二者的区别是:useradd命令创建用户后,不会在/home目录下创建同名文件夹,也不会创建密码,因此想要正常登陆还需要后续设置,比较麻烦;而adduser命令创建用户后,会通过提示的形式完成相关所需操作,较为方便。

PS:删除用户,只需使用命令deluser 用户名即可,一般希望把它留在系统上的文件也删除掉,此时可以使用deluser -r 用户名来实现。

  • 通过adduser命令创建新用户“newuser
root@instance-t009xqlo:~# adduser newuser
Adding user `newuser' ...
Adding new group `newuser' (1003) ...
Adding new user `newuser' (1003) with group `newuser' ...
Creating home directory `/home/newuser' ...
Copying files from `/etc/skel' ...
Enter new UNIX password:
Retype new UNIX password:
passwd: password updated successfully
Changing the user information for newuser
Enter the new value, or press ENTER for the default
        Full Name []: newuser
        Room Number []:
        Work Phone []:
        Home Phone []:
        Other []:
Is the information correct? [Y/n] y
root@instance-t009xqlo:~#

但此时新用户“newuser”执行sudo命令会出现提示“newuser is not in the sudoers file. This incident will be reported”,还需要将新用户添加到sudoers列表中。

  • 将新用户添加到sudoers列表中
#进入管理员root权限
newuser@instance-t009xqlo:~$ su
Password:
#用时vim编辑sudoers列表
root@instance-t009xqlo:/home/newuser# vim /etc/sudoers

在sudoers列表中添加上面一行,随后强制保存退出(wq!)即可。

在服务器中创建FTP服务

为了便于在服务器和本地电脑间实现安全的文件传输,在服务器上搭建FTP服务。该部分配置主要参见了CSDN博文(https://blog.csdn.net/soslinken/article/details/79304076)。

  • 安装vsftpd

    $ sudo apt-get install vsftpd
    
  • 备份vsftpd配置文件

    $ sudo cp /etc/vsftpd.conf /etc/vsftpd.conf.bak
    
  • 修改vsftpd配置文件

    $ sudo vim /etc/vsftpd.conf
    

    配置文件主要配置如下

    listen=NO
    listen_ipv6=YES
    anonymous_enable=NO
    local_enable=YES
    write_enable=YES
    local_umask=022
    dirmessage_enable=YES
    use_localtime=YES
    xferlog_enable=YES
    connect_from_port_20=YES
    xferlog_file=/var/log/vsftpd.log
    xferlog_std_format=YES
    ftpd_banner=Welcome to Snail FTP service.
    chroot_list_enable=YES
    chroot_list_file=/etc/vsftpd.chroot_list
    secure_chroot_dir=/var/run/vsftpd/empty
    pam_service_name=ftp
    rsa_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem
    rsa_private_key_file=/etc/ssl/private/ssl-cert-snakeoil.key
    ssl_enable=NO
    utf8_filesystem=YES
    userlist_enable=YES
    userlist_deny=NO
    userlist_file=/etc/vsftpd.user_list
    allow_writeable_chroot=YES
    
  • 创建FTP目录和登陆用户

    #先创建ftp目录
    $ sudo mkdir /home/ftp
    #添加用户
    $ sudo useradd -d /home/ftp -s /bin/bash ftpuser
    #设置用户密码
    $ sudo passwd ftpuser
    #设置ftp目录用户权限
    $ sudo chown ftpuser:ftpuser /home/ftp
    #在etc目录下新建文件vsftpd.user_list,用于存放允许访问ftp的用户
    $ sudo touch /etc/vsftpd.user_list
    #编辑vsftpd.user_list,在其中添加ftpuser
    $ sudo vim /etc/vsftpd.user_list
    #在etc目录下新建文件vsftpd.chroot_list,设置可列出、切换目录的用户
    $ sudo touch /etc/vsftpd.chroot_list
    #编辑chroot_list,在其中添加ftpuser
    $ sudo vim /etc/vsftpd.chroot_list
    
  • 重启vsftpd服务

    $ sudo service vsftpd restart
    

配置完成后即可利用FileZilla在本地通过FTP连接服务器

在服务器中安装Anaconda

折腾Ubuntu服务器的初衷是学习Python,为了省心,直接在服务器上安装Anaconda。

Anaconda是一个开源的包、环境管理器,含了conda、Python等180多个科学包及其依赖项,可以用于在同一个机器上安装不同版本的软件包及其依赖,并能够在不同的环境之间切换。

安装时最新的Anaconda安装包约654 MB,可以下载至本地后通过前面搭建的FTP服务传输至服务器(该方法似乎有点自找麻烦),也可以直接在服务器中运行下面语句下载。

$ wget https://repo.anaconda.com/archive/Anaconda3-2019.03-Linux-x86_64.sh

下载完成后,在文件所在目录运行如下语句,按提示安装即可。

$ bash Anaconda3-2018.12-Linux-x86_64.sh

安装完成后在终端中输入python,可以看到运行的python版本信息已经从此前系统默认的python2.7变为了python3.7,同时出现了 Anaconda, Inc. on linux信息。

PS:如果此时运行python还是运行默认的python2.7,则在终端中运行如下语句即可解决。

$ source ~/.bashrc

配置jupyter notebook,实现远程登录

Jupyter Notebook是一个交互式笔记本,支持运行 40 多种编程语言,其本质是一个 Web 应用程序,便于创建和共享文学化程序文档,支持实时代码,数学方程,可视化和 markdown,用途包括数据清理和转换,数值模拟,统计建模,机器学习等等。

  • 生成jupyter notebook配置文件

    $ jupyter notebook --generate-config
    
  • 设置登陆密码

    $ jupyter notebook password
    
  • 修改配置文件

    $ vim ~/.jupyter/jupyter_notebook_config.py
    

    具体配置信息如下

    c.NotebookApp.allow_remote_access = True
    c.NotebookApp.allow_root = True
    c.NotebookApp.ip = '*'
    c.NotebookApp.notebook_dir = '/home/snail/data/jupyter'
    c.NotebookApp.open_browser = False
    c.NotebookApp.port = 8888
    
  • 配置百度云安全组

    在百度云中创建安全组,将jupyter的端口8888加入到入站规则中,然后在实例中关联所创建的安全组即可。

  • 在服务器后台运行jupyter notebook

    如果直接在服务器终端中输入jupyter notebook命令,则终端关闭后服务即停止运行,因此如果想实现对服务器的随时访问,需让jupyter notebook后台运行。

    $ nohup jupyter notebook &
    

    其中,nohup 指的是不挂起,而&是后台运行

    PS:如果后续想关闭后台运行,则执行ps -ef | grep jupyter命令查询进程PID,然后执行kill -9 查询到的进程PID命令杀掉进程即可。

在浏览器中输入公网IP即可访问服务器jupyter notebook

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352