Skip to content

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.ymlconfig.yml

  • a.将config.yml里面的 DB_PASSWORDREDIS_PASSWORDDEBUG 取消注释

  • b.随机生成并填写 SECRET_KEY, 随便写一些字符就行

  • c.将DB_HOSTREDIS_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

B.使用编辑器启动服务[自行配置或者询问deepseek]