windows11 下本地开发环境搭建
一.基础环境安装【仅操作一次】基于Windows中wsl操作
1.wsl Ubuntu子系统安装
打开cmd命令框,输入下面命令,根据提示操作
shell
wsl --install
根据提示输入用户名和密码
为了方便操作,建议切换root用户进行操作
shell
sudo su # 输入上面的密码
2.环境依赖更新
shell
apt update -y
3安装postgresql依赖环境
shell
apt install postgresql-16 -y
systemctl enable postgresql
systemctl restart postgresql
创建数据库并添加授权
shell
su - postgres
shell
cat <<EOF > create_and_permission.sql
-- 创建数据库
create database xadmin;
-- 创建用户并设置密码
CREATE USER server WITH PASSWORD 'KGzKjZpWBp4R4RSa';
-- 授予用户对数据库的所有权限
GRANT ALL PRIVILEGES ON DATABASE xadmin TO server;
-- 切换到xadmin数据库
\c xadmin;
-- 授予用户对 schema 的使用和创建权限
GRANT USAGE ON SCHEMA public TO server;
GRANT CREATE ON SCHEMA public TO server;
-- 授予用户对 schema 中现有对象(如表和序列)的权限
GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO server;
GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public TO server;
-- 配置默认权限,确保未来创建的表和序列也授予用户权限
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON TABLES TO server;
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON SEQUENCES TO server;
EOF
psql -f create_and_permission.sql
exit
4.安装启动Redis,并设置所需密码和hosts解析
shell
apt install redis-server -y
echo -e '\nrequirepass nineven' >> /etc/redis/redis.conf # 用于添加redis密码
systemctl enable redis-server
systemctl restart redis-server
切记,上面的操作都在Windows的子系统中操作,下面的操作在编辑器中操作
二.服务端开发操作
5.开启子系统,且该窗口不可以关闭,若关闭,则Redis和Postgresql 服务将会终止,在cmd中通过下面该命令启动子系统
shell
wsl -d Ubuntu
6.修改 server 配置文件,复制config_example.yml
为config.yml
a.将config.yml里面的
DB_PASSWORD
,REDIS_PASSWORD
,DEBUG
取消注释b.随机生成并填写
SECRET_KEY
, 随便写一些字符就行c.将
DB_HOST
和REDIS_HOST
的值修改为127.0.0.1
7.生成数据表并迁移【server中所需的Python3.13.2环境和依赖自行安装】
shell
python manage.py makemigrations
python manage.py migrate
8.编译国际化,下载IP数据库
shell
python manage.py compilemessages # 如果该命令报错,提示找不到msgfmt,参考第12个常见问题
python manage.py download_ip_db -f
9.创建超级管理员
shell
python manage.py createsuperuser
10.导入默认菜单,权限,角色等数据(仅新部署执行一次)
shell
python manage.py load_init_json
11.启动程序
A.手动执行命令【下面命令一般是开发阶段操作】
1.api服务
shell
python manage.py runserver 0.0.0.0:8896
2.定时任务
shell
python -m celery -A server beat -l INFO --scheduler django_celery_beat.schedulers:DatabaseScheduler --max-interval 60
shell
python -m celery -A server worker -P threads -l INFO -c 10 -Q celery --heartbeat-interval 10 -n celery@%h --without-mingle
3.任务监控[可能某些Windows系统无法正常运行,导致页面打不开]
shell
python -m celery -A server flower -logging=info --url_prefix=api/flower --auto_refresh=False --address=0.0.0.0 --port=5566