OSError:[Errno 13]权限被拒绝:' / var / lib / pgadmin'

时间:2017-10-12 11:00:10

标签: pgadmin-4

Ubuntu 16.04.3

我想安装pgAdmin:

我用python 2创建了一个virtualenv。

然后安装pgAdmin 4 v2.0:

pip install https://ftp.postgresql.org/pub/pgadmin/pgadmin4/v2.0/pip/pgadmin4-2.0-py2.py3-none-any.whl

现在是时候运行pgAdmin了:

(pgadmin4) michael@michael-desktop:~/PycharmProjects/venv$ python pgadmin4/lib/python2.7/site-packages/pgadmin4/pgAdmin4.py
Traceback (most recent call last):
  File "pgadmin4/lib/python2.7/site-packages/pgadmin4/pgAdmin4.py", line 55, in <module>
    exec(open(file_quote(setupfile), 'r').read())
  File "<string>", line 46, in <module>
  File "/home/michael/PycharmProjects/venv/pgadmin4/lib/python2.7/site-packages/pgadmin4/pgadmin/setup/data_directory.py", line 23, in create_app_data_directory
    _create_directory_if_not_exists(os.path.dirname(config.SQLITE_PATH))
  File "/home/michael/PycharmProjects/venv/pgadmin4/lib/python2.7/site-packages/pgadmin4/pgadmin/setup/data_directory.py", line 15, in _create_directory_if_not_exists
    os.mkdir(_path)
OSError: [Errno 13] Permission denied: '/var/lib/pgadmin'

你能帮我一把吗?

6 个答案:

答案 0 :(得分:22)

如果您不想更改任何内容的权限,则始终可以覆盖pgAdmin4中的默认路径。

在您的安装位置创建一个名为config_local.py的文件(如果尚未存在)../pgadmin4/web/

  

我的案例中的文件位置:   /usr/local/lib/python2.7/dist-packages/pgadmin4/config_local.py

并在config_local.py

中添加以下代码
import os
DATA_DIR = os.path.realpath(os.path.expanduser(u'~/.pgadmin/'))
LOG_FILE = os.path.join(DATA_DIR, 'pgadmin4.log')
SQLITE_PATH = os.path.join(DATA_DIR, 'pgadmin4.db')
SESSION_DB_PATH = os.path.join(DATA_DIR, 'sessions') 
STORAGE_DIR = os.path.join(DATA_DIR, 'storage')

重新启动pgAdmin4并检查。

答案 1 :(得分:0)

权限错误意味着用户'michael'(/ var / lib具有drwxr-xr-x)具有执行权限但无权写入文件夹(根据您对以下文件夹信息的评论) )。 您可以使用的其中一个解决方案是:

chown -R michael:root /path/to/the/directory

答案的第二部分,你已经弄清楚了@Michael。 使用以下命令下载pgadmin:

wget https://ftp.postgresql.org/pub/pgadmin/pgadmin4/v1.5/pip/pgadmin4-1.5-py2.py3-none-any.whl 

然后执行命令:

pip install pgadmin4*.whl.

答案 2 :(得分:0)

手动创建文件夹(或添加到pgAdmin安装脚本,如果有),并分配权限:

sudo mkdir "/var/log/pgadmin"
sudo chmod a+wrx "/var/log/pgadmin"

sudo mkdir "/var/lib/pgadmin"
sudo chmod a+wrx "/var/lib/pgadmin"

这不会为整个/var/log分配权限,而只是为/var/log/pgadmin分配权限。

答案 3 :(得分:0)

我在Ubuntu 16.04上安装了pgadmin4 v2.1并遇到了这个问题。查看最后一行代码。 (我在一个脚本文件中运行它,懒惰。)我也以这种方式安装2.0作为测试,看它是否真的是一个修复。我不必使用config_local.py

cd ..
cd home/vagrant

sudo apt-get install build-essential libssl-dev libffi-dev libgmp3-dev virtualenv python-pip libpq-dev python-dev

virtualenv .pgadmin4
cd .pgadmin4
source bin/activate

wget https://ftp.postgresql.org/pub/pgadmin/pgadmin4/v2.1/pip/pgadmin4-2.1-py2.py3-none-any.whl

pip install pgadmin4-2.1-py2.py3-none-any.whl

# For this either use your remote host panel to edit the file or:
nano lib/python2.7/site-packages/pgadmin4/config.py
# Change:
# DEFAULT_SERVER = '0.0.0.0'

# Here is the trick.  Run this boot up file with sudo.  This fixed it for me.
sudo python lib/python2.7/site-packages/pgadmin4/pgAdmin4.py

答案 4 :(得分:0)

我在pgAdmin4 v3.1上也遇到了同样的问题,我只写了sudo python pgAdmin4.py,就可以了!

答案 5 :(得分:0)

通过几个步骤解决了问题 1.在主机vm上创建空文件夹

mkdir /private/var/lib/pgadmin
chmod 777 /private/var/lib/pgadmin
  1. 启动pgadmin docker镜像
docker pull dpage/pgadmin4
docker run -p 80:80\
    -v /private/var/lib/pgadmin:/var/lib/pgadmin \
     ...
  1. 您将看到这样新创建的文件结构
/private/var/lib/pgadmin

-rw-------.  1 5050 5050 757760 Jan 13 23:11 pgadmin4.db
drwx------.  2 5050 5050     50 Jan 13 23:00 sessions
drwxr-xr-x.  3 5050 5050     31 Jan 13 23:17 storage

因此,UID 5050是我们的目标之一 4.将您的pgadmin4.db复制到目标目录,并应用适当的UID [在我的情况下为5050]

结果应用程序将运行,用户设置将被保存。