美文网首页
# 在windows上安装Discourse全过程

# 在windows上安装Discourse全过程

作者: 马鹏飞_47c5 | 来源:发表于2020-12-23 22:49 被阅读0次

购买腾讯云在硅谷的云主机,按量计费,半个小时就安装好,总共花费一块钱左右。国内的网络环境安装discourse是不太可能的。

#更新软件列表
sudo apt-get update
#安装包的时候要根据提示输入y确认
sudo apt-get install apt-transport-https ca-certificates curl gnupg2 software-properties-common netcat
#安装docker-ce
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/ubuntu \
$(lsb_release -cs) \
stable"
sudo apt-get install docker-ce
#启动docker
sudo service docker start
#下载discourse_docker
sudo git clone https://github.com/discourse/discourse_docker.git /var/discourse
# app.yml文件本来是不存在的,需要自己上传
sudo mv app.yml /var/discourse
# 运行程序
cd /var/discourse
sudo ./launcher rebuild app
## app.yml文件
##
## this is the all-in-one, standalone Discourse Docker container template
##
## After making changes to this file, you MUST rebuild
## /var/discourse/launcher rebuild app
##
## BE *VERY* CAREFUL WHEN EDITING!
## YAML FILES ARE SUPER SUPER SENSITIVE TO MISTAKES IN WHITESPACE OR ALIGNMENT!
## visit http://www.yamllint.com/ to validate this file as needed

templates:
  - "templates/postgres.template.yml"
  - "templates/redis.template.yml"
  - "templates/web.template.yml"
  - "templates/web.ratelimited.template.yml"
## Uncomment these two lines if you wish to add Lets Encrypt (https)
##  - "templates/web.ssl.template.yml"
##  - "templates/web.letsencrypt.ssl.template.yml"

## which TCP/IP ports should this container expose?
## If you want Discourse to share a port with another webserver like Apache or nginx,
## see https://meta.discourse.org/t/17247 for details
expose:
  - "80:80"   # http
  - "443:443" # https

params:
  db_default_text_search_config: "pg_catalog.english"

  ## Set db_shared_buffers to a max of 25% of the total memory.
  ## will be set automatically by bootstrap based on detected RAM, or you can override
  db_shared_buffers: "128MB"

  ## can improve sorting performance, but adds memory usage per-connection
  #db_work_mem: "40MB"

  ## Which Git revision should this container use? (default: tests-passed)
  #version: tests-passed

env:
  LANG: en_US.UTF-8
  # DISCOURSE_DEFAULT_LOCALE: en

  ## How many concurrent web requests are supported? Depends on memory and CPU cores.
  ## will be set automatically by bootstrap based on detected CPUs, or you can override
  UNICORN_WORKERS: 2

  ## TODO: The domain name this Discourse instance will respond to
  ## Required. Discourse will not work with a bare IP number.
  DISCOURSE_HOSTNAME: discourse.mapengfei.xyz

  ## Uncomment if you want the container to be started with the same
  ## hostname (-h option) as specified above (default "$hostname-$config")
  #DOCKER_USE_HOSTNAME: true

  ## TODO: List of comma delimited emails that will be made admin and developer
  ## on initial signup example 'user1@example.com,user2@example.com'
  DISCOURSE_DEVELOPER_EMAILS: '499908174@qq.com'

  ## TODO: The SMTP mail server used to validate new accounts and send notifications
  ## SMTP ADDRESS, username, and password are required
  ## WARNING the char '#' in SMTP password can cause problems!
  DISCOURSE_SMTP_ADDRESS: smtp.******
  DISCOURSE_SMTP_PORT: ***
  DISCOURSE_SMTP_USER_NAME: ****
  DISCOURSE_SMTP_PASSWORD: "****"
  DISCOURSE_SMTP_AUTHENTICATION: login
  DISCOURSE_SMTP_ENABLE_START_TLS: false           # (optional, default true)
  
  ## If you added the Lets Encrypt template, uncomment below to get a free SSL certificate
  LETSENCRYPT_ACCOUNT_EMAIL: 499908174@qq.com

  ## The http or https CDN address for this Discourse instance (configured to pull)
  ## see https://meta.discourse.org/t/14857 for details
  #DISCOURSE_CDN_URL: https://discourse-cdn.example.com

## Plugins go here
## see https://meta.discourse.org/t/19157 for details
hooks:
  after_code:
    - exec:
        cd: $home/plugins
        cmd:
          - git clone https://github.com/discourse/docker_manager.git
          - sudo -E -u discourse git clone https://github.com/discourse/discourse-math.git
          - sudo -E -u discourse git clone https://github.com/discourse/discourse-calendar.git
          - sudo -E -u discourse git clone https://github.com/paviliondev/discourse-topic-previews.git

## Any custom commands to run after building
run:
  - exec: echo "Beginning of custom commands"
  ## If you want to set the 'From' email address for your first registration, uncomment and change:
  ## After getting the first signup email, re-comment the line. It only needs to run once.
  #- exec: rails r "SiteSetting.notification_email='info@unconfigured.discourse.org'"
  - exec: rails r "SiteSetting.notification_email='mapengfei@mail.nwpu.edu.cn'"
  - exec: echo "End of custom commands"

编译好以后,最终会下面这个命令。把编译好的镜像放到本地,然后将刚才的命令复制到windows命令行里,discourse就能运行了http://localhost/

docker run --shm-size=512m -d --restart=always -e LANG=en_US.UTF-8 -e RAILS_ENV=production -e UNICORN_WORKERS=2 -e UNICORN_SIDEKIQS=1 -e RUBY_GLOBAL_METHOD_CACHE_SIZE=131072 -e RUBY_GC_HEAP_GROWTH_MAX_SLOTS=40000 -e RUBY_GC_HEAP_INIT_SLOTS=400000 -e RUBY_GC_HEAP_OLDOBJECT_LIMIT_FACTOR=1.5 -e DISCOURSE_DB_SOCKET=/var/run/postgresql -e DISCOURSE_DB_HOST= -e DISCOURSE_DB_PORT= -e DISCOURSE_HOSTNAME=disco*******yz -e DISCOURSE_DEVELOPER_EMAILS=499908174@qq.com -e DISCOURSE_SMTP_ADDRESS=****************** -e DISCOURSE_SMTP_PORT=25 -e DISCOURSE_SMTP_USER_NAME=m**********n -e DISCOURSE_SMTP_PASSWORD=********** -e DISCOURSE_SMTP_AUTHENTICATION=login -e DISCOURSE_SMTP_ENABLE_START_TLS=false -e LETSENCRYPT_ACCOUNT_EMAIL=49990*******om -h VM-0-10-ubuntu-app -e DOCKER_HOST_IP=172.17.0.1 --name app -t -p 80:80 -p 443:443 --mac-address 02:96:d8:db:2e:4c local_discourse/app /sbin/boot

相关文章

网友评论

      本文标题:# 在windows上安装Discourse全过程

      本文链接:https://www.haomeiwen.com/subject/ulcpnktx.html