Ubuntu16.04下使用virtualenv创建各版本python的虚拟环境

本文详细阐述了为何使用virtualenv:解决Python版本冲突,创建和管理隔离环境,以及如何通过步骤激活和退出。通过实例演示了如何在开发中保护系统和避免包混乱。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

为什么要使用virtualenv?


首先,virtualenv为应用提供了隔离的Python运行环境,可以解决不同应用间多版本的冲突问题。

比如,现在的电脑中一般同时具有python2和python3,系统的运行需要python2,做开发时往往需要更新的python3。而在使用工具pip时,所有第三方的包都会被安装到默认的python(一般是python2)的site-packages目录下,有时这不是我们所希望的。

这正是要用到virtualenv的场合。virtualenv会把用户指定版本的python复制到虚拟环境下,并修改相关的环境变量,使得python和pip命令指向当前虚拟环境。用户可以在虚拟环境中任意操作,而不会对外部造成影响。

1. 安装virtualenv

pip install virtualenv

2. 查看python3目录(其他版本也可)

which python3
#我的python3是在/usr/bin/python3

3.创建python3虚拟环境

virtualenv -p /usr/bin/python3 py3env

其中,
-p /usr/bin/python3指定了要复制的python的目录
py3env是存放环境的文件夹名称

4. 激活虚拟环境

#使用source命令来使得环境变量修改后立即生效
source /root/py3env/bin/activate

可以看到命令提示符有一个(py3env)的前缀,即表示激活成功。
此时,你的所有python、pip操作都会指向虚拟环境创建时复制的那一份python
比如再次执行which python,如图。

原来的路径是/usr/bin/python3,激活虚拟环境后是/root/py3env/bin/python

5.退出虚拟环境

deactivate

(py3env)前缀消失,环境变量被重设为原来的。

6. Tip

切记要在工作时激活虚拟环境,结束工作后退出。

看起来你遇到了Hadoop分布式文件系统(HDFS)之间通信的问题,具体表现为`Call From`主机到另一个主机的连接失败。这通常与网络设置、防火墙配置以及Hadoop守护进程的安全性有关。以下是可能的原因和解决方案: 报错原因: 1. **防火墙阻止**:如果主节点(hadoop1)的9000端口受到防火墙限制,导致其他节点无法连接。 2. **端口未开放**:即使防火墙允许,也可能是因为主节点的9000端口并未开启,用于接收客户端请求。 3. **远程访问权限**:即使端口开放,若设置了只允许本地连接,那么外部节点会收到拒绝连接。 报错解决步骤(简易版本)[^2]: 1. **检查防火墙设置**:确认主节点的防火墙是否允许来自其他节点的TCP连接,特别是9000端口。 ```shell sudo ufw allow from <slave_ip> to any port 9000 ``` 2. **启动Hadoop服务**:确保Hadoop在主节点上运行并且NameNode(可能是`hdfs namenode -format`后的结果)正在监听9000端口。 3. **修改配置**:检查`core-site.xml`或`hdfs-site.xml`中的`<dfs.http.address>`配置,确保允许远程访问。默认应为`localhost`,需改为全网地址如`0.0.0.0`。 4. **重启Hadoop服务**:如果上述步骤调整了配置,需要重启Hadoop以应用新的设置。 ```shell sudo service hadoop-daemon restart namenode ``` 如果你遇到类似`mkdir: Call From hadoop102/192.168.45.102 to hadoop102:8020 failed on connection exception: java.net...`的错误,可能说明尝试连接的节点自身存在问题,或者是网络环境内部的连通性问题。检查hadoop102自身的网络设置和Hadoop服务状态也是必要的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值