रेडमाइन एक लचीला और ओपन-सोर्स प्रोजेक्ट प्रबंधन और इश्यू-ट्रैकिंग वेब एप्लिकेशन है। इसका व्यापक रूप से परियोजनाओं के प्रबंधन, बग्स पर नज़र रखने और कार्यों और समय-सीमाओं को संभालने के लिए उपयोग किया जाता है। रूबी ऑन रेल्स का उपयोग करके विकसित, रेडमाइन अत्यधिक अनुकूलन योग्य है और टीम सहयोग और परियोजना संगठन के लिए सुविधाओं की एक विस्तृत श्रृंखला का समर्थन करता है।
रेडमाइन अपने लचीलेपन, अनुकूलन और ओपन-सोर्स प्रकृति के कारण वाणिज्यिक परियोजना प्रबंधन टूल का एक लोकप्रिय विकल्प है।
इस लेख में हम डेटाबेस सर्वर, MySQL और nginx के साथ डॉकर कंटेनर पर रिवर्स प्रॉक्सी के रूप में रेडमाइन सेटअप करेंगे।
हम AWS EC2 पर होस्ट किए गए ubuntu सर्वर और docker अधिकारी से इंस्टॉलेशन गाइड का उपयोग करते हैं।
# Add Docker's official GPG key: sudo apt-get update sudo apt-get install ca-certificates curl sudo install -m 0755 -d /etc/apt/keyrings sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc sudo chmod a r /etc/apt/keyrings/docker.asc # Add the repository to Apt sources: echo \ "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \ $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \ sudo tee /etc/apt/sources.list.d/docker.list > /dev/null sudo apt-get update
हम डॉकर कंपोज़ के साथ डॉकर के नवीनतम संस्करण का उपयोग करते हैं।
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
ठीक है, डॉकर इंस्टॉल हो गया है, इसके बाद हमें अपने उपयोगकर्ता को कॉन्फ़िगर करने की आवश्यकता है (उबंटू) सुडो के बिना सीधे डॉकर तक पहुंच सकता है।
sudo groupadd docker sudo usermod -aG docker $USER
और फिर लॉगआउट करें और हमारे सर्वर पर फिर से लॉगिन करें। डॉकर तैयार है!
जब हमारा सर्वर पुनरारंभ होता है तो हम डॉकटर कंटेनर को प्रारंभ करने के लिए नीचे दिए गए इस कमांड का उपयोग कर सकते हैं।
sudo systemctl enable docker.service sudo systemctl enable containerd.service
डॉकटर कंटेनर अभी के लिए पर्याप्त है।
हम एक डॉकर कंपोज़ फ़ाइल बनाएंगे।
nano docker-compose.yaml
और इस yaml कोड को पेस्ट करें।
version: '3.1' services: nginx: # we use the latest of nginx as base image: nginx:latest restart: always # we expose port 80 and 443 to the public as our reverse proxy ports: - "80:80" - "443:443" volumes: # we link volume from host for nginx configuration - './nginx.conf:/etc/nginx/conf.d/nginx.conf' # we link volume from host for nginx certs - './certs:/etc/nginx/certs' # we link also timezone from the host - '/etc/localtime:/etc/localtime:ro' - '/etc/timezone:/etc/timezone:ro' depends_on: # we will wait until server redmine is ready - redmine redmine: # we use redmine from dockerhub as base image: redmine restart: always volumes: # we link redmine data to our local storage, so it will persistent when # the service redmine restarted - 'redmine_data:/usr/src/redmine/files' # we link redmine plugin also from the host - '/home/bkn/redmine_plugins:/usr/src/redmine/plugins' # we link also timezone from the host - '/etc/localtime:/etc/localtime:ro' - '/etc/timezone:/etc/timezone:ro' # we don't expose port on this service because nginx service will do # default port redmine expose internally is 3000 #ports: #- 3000:3000 #- 444:3000 environment: # we create some env for redmine REDMINE_DB_MYSQL: db REDMINE_DB_PORT: 3306 REDMINE_DB_DATABASE: redmine_db REDMINE_DB_USERNAME: redmine REDMINE_DB_PASSWORD: my_p@ssword REDMINE_SECRET_KEY_BASE: G75eddsecretkey # we will wait until db service is ready depends_on: - db db: # we use mysql server for redmine database image: mysql:8.0 restart: always volumes: # we also link the database storage with volume we created below - 'mysql_data:/var/lib/mysql' environment: # we create some env for mysql MYSQL_USER: redmine MYSQL_PASSWORD: my_p@ssword MYSQL_RANDOM_ROOT_PASSWORD: 1 MYSQL_ROOT_PASSWORD: JRFFHT534rth4u3!@# MYSQL_DATABASE: redmine_db volumes: # we create two volume used by redmine and our database mysql_data: driver: local redmine_data: driver: local
इसके बाद, हम nginx कॉन्फ़िगरेशन फ़ाइल बनाते हैं, docker-compose फ़ाइल के समान फ़ोल्डर
nano nginx/nginx.conf
server { listen 80; server_name proman.withenri.tech; location / { proxy_pass http://henri_redmine_1:3000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } server { listen 443 ssl; server_name proman.withenri.tech; ssl_certificate /etc/nginx/certs/withenri.tech_chained.crt; ssl_certificate_key /etc/nginx/certs/withenri.tech.key; location / { proxy_pass http://henri_redmine_1:3000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } }
और सेर्ट्स नामक फ़ोल्डर बनाएं और फिर हमारे प्रमाणपत्रों को वहीं रखें।
आइए कमांड के साथ अपनी डॉकर कंपोज़ फ़ाइल चलाएं
docker-compose up -d
जब हम इस डॉकर कंपोज़ फ़ाइल को चलाते हैं, तो एक नेटवर्क स्वचालित रूप से बन जाएगा और उन एक नेटवर्क में तीन सेवाओं (nginx, Redmine, db) को लिंक कर देगा।
हम अपने कंटेनर को कमांड से जांच सकते हैं:
docker ps -a
और फिर हमारे ब्राउज़र पर पोर्ट 80 और पोर्ट 443 के साथ https कनेक्शन के साथ रेडमाइन एप्लिकेशन का परीक्षण करें। हमारे रेडमाइन एप्लिकेशन पर लॉगिन के लिए उपयोगकर्ता 'एडमिन' और पासवर्ड 'एडमिन' का उपयोग करें।
इस लेख का मूलतः वही परिणाम है जब हम सीधे वीपीएस पर स्थापित करते हैं, इस लेख को देखें।
उम्मीद है कि यह लेख आपकी मदद करेगा!
अस्वीकरण: उपलब्ध कराए गए सभी संसाधन आंशिक रूप से इंटरनेट से हैं। यदि आपके कॉपीराइट या अन्य अधिकारों और हितों का कोई उल्लंघन होता है, तो कृपया विस्तृत कारण बताएं और कॉपीराइट या अधिकारों और हितों का प्रमाण प्रदान करें और फिर इसे ईमेल पर भेजें: [email protected] हम इसे आपके लिए यथाशीघ्र संभालेंगे।
Copyright© 2022 湘ICP备2022001581号-3