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'
你能帮我一把吗?
答案 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
docker pull dpage/pgadmin4 docker run -p 80:80\ -v /private/var/lib/pgadmin:/var/lib/pgadmin \
...
/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]
结果应用程序将运行,用户设置将被保存。