jupyer虚拟机远程访问配置

由于将jupyter装在了服务器,想在本地访问jupyter的kernel。

不知道是不是必须要在同一网段,由于学校访问问题,目前是必须确认在同一网段下。

开始配置:

  1. 生成配置文件
    (我这里是使用root用户进行配置的,但是建议最好使用普通用户)
[root@localhost Python-3.6.5]# jupyter notebook --generate-config
Writing default config to: /root/.jupyter/jupyter_notebook_config.py
  1. 生成密码文件
    如果你想远程访问jupyter时,需要使用密码登入,就可以有这一步,自己使用的话,嗯最好还是弄一个吧。
## Hashed password to use for web authentication.
# 
# To generate, type in a python/IPython shell:
# 
# from notebook.auth import passwd; passwd()
# 
# The string should be of the form type:salt:hashed-password.
#c.NotebookApp.password = ''

可以看到文件中给出了如何生成密码文件的方法:

[root@localhost Python-3.6.5]# python3
Python 3.6.5 (default, Jan 10 2019, 04:19:43) 
[GCC 4.8.5 20150623 (Red Hat 4.8.5-36)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from notebook.auth import passwd;passwd()
Enter password: 
Verify password: 
'sha1:ac5012e9f4***********706f19ee9938bef6'

一定记得复制一下这串sha1码。

  1. 修改配置文件,实现远程访问
    打开我们在第一步生成的配置文件,
    ## The IP address the notebook server will listen on. c.NotebookApp.ip = '0.0.0.0'
    204行将localhost改为*,意为允许任何ip访问。
    c.NotebookApp.open_browser = False
    267行将True改为False。并将句前的#去掉。防止主动打开浏览器。
    c.NotebookApp.password = 'sha1:ac5012e9f4ce:bdfdd4b96f6d5cf59aa484a1706f19ee9938bef6‘
    276行同去掉#,将上一步中生成的sha码,复制到这里。
    c.NotebookApp.port = 8855
    287行的将端口前的#去掉,端口可以修改可以不改,自己顺心就好。

保存,退出。

我在安装的时候出现了很多闹心的问题,一个一个来解决吧
系统,centos7,python3.6.5,jupyter最新的。

socket.gaierror: [Errno -2] Name or service not known
OSError: [Errno 99] Cannot assign requested address

首先确认你的防火墙是否关闭
centos7的命令如下:

firewall-cmd --state#查看防火墙状态
systemctl stop firewalld.service #停止firewall
systemctl disable firewalld.service #禁止firewall开机启动

有网友说,在/etc/hostname中加入

127.0.0.1 localhost

我没发现有什么区别。
然后就是我用的root用户启动需要加--allow-root参数。

jupyter notebook --allow-root

然后在本地电脑输入服务器的ip:端口号就可以访问啦。

全部评论

相关推荐

03-04 19:02
云南大学 Java
Yki_:没挂,只是没人捞,该干啥干啥,等着就好了
点赞 评论 收藏
分享
会飞的猿:我看你想进大厂,我给你总结一下学习路线吧,java语言方面常规八股要熟,那些java的集合,重点背hashmap八股吧,jvm类加载机制,运行时分区,垃圾回收算法,垃圾回收器CMS、G1这些,各种乐观锁悲观锁,线程安全,threadlocal这些。在进阶一些的比如jvm参数,内存溢出泄漏排查,jvm调优。我这里说的只是冰山一角,详细八股可以去网上找,这不用去买,都免费资源。mysql、redis可以去看小林coding,我看你简历上写了,你一定要熟,什么底层b+树、索引结构、innodb、mvcc、undo log、redo log、行级锁表级锁,这些东西高频出现,如果面试官问我这些我都能笑出来。消息队列rabbitmq也好kafka也好,学一种就行,什么分区啊副本啊确认机制啊怎么保证不重复消费、怎么保证消息不丢失这些基本的一定要会,进阶一点的比如LEO、高水位线、kafka和rocketmq底层零拷贝的区别等等。计算机网络和操作系统既然你是科班应该理解起来问题不大,去看小林coding这两块吧,深度够了。spring boot的八股好好看看吧,一般字节腾讯不这么问,其他的java大厂挺爱问的,什么循环依赖啥的去网上看看。数据结构的话科班应该问题不大,多去力扣集中突击刷题吧。项目的话其实说白了还是结合八股来,想一想你写的这些技术会给你挖什么坑。除此之外,还有场景题、rpc、设计模式、linux命令、ddd等。不会的就别往简历上写了,虽然技术栈很多的话好看些,但背起来确实累。总结一下,多去实习吧,多跳槽,直到跳到一个不错的中厂做跳板,这是一条可行的进大厂的路线。另外,只想找个小厂的工作的话,没必要全都照这些准备,太累了,重点放在框架的使用和一些基础八股吧。大致路线就这样,没啥太多难度,就是量大,你能达到什么高度取决于你对自己多狠,祝好。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务