File size: 9,732 Bytes
3947f52
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
# 🌐 راهنمای استقرار (Deployment Guide)

این فایل شامل دستورالعمل کامل برای استقرار داشبورد کریپتو در پلتفرم‌های مختلف است.

---

## 📋 فهرست

1. [Hugging Face Spaces](#1-hugging-face-spaces)
2. [Railway.app](#2-railwayapp)
3. [Render.com](#3-rendercom)
4. [Oracle Cloud (رایگان)](#4-oracle-cloud-رایگان)
5. [Vercel](#5-vercel)
6. [Docker (محلی)](#6-docker-محلی)
7. [VPS / سرور اختصاصی](#7-vps--سرور-اختصاصی)

---

## 1. Hugging Face Spaces

### 🎯 مزایا
- ✅ رایگان
- ✅ راه‌اندازی سریع
- ✅ URL عمومی
- ✅ مناسب برای demo

### 📝 مراحل استقرار

#### روش 1: استفاده از Docker (توصیه می‌شود)

1. **ایجاد Space جدید**
   - به [huggingface.co/spaces](https://huggingface.co/spaces) بروید
   - روی "Create new Space" کلیک کنید
   - نام Space را وارد کنید
   - SDK را روی **Docker** تنظیم کنید

2. **آپلود فایل‌ها**
   ```bash
   git clone https://huggingface.co/spaces/YOUR_USERNAME/YOUR_SPACE
   cd YOUR_SPACE
   
   # کپی فایل‌های پروژه
   cp -r crypto_dashboard/* .
   
   git add .
   git commit -m "Initial commit"
   git push
   ```

3. **تنظیم Port**
   در فایل `Dockerfile` مطمئن شوید که port 7860 استفاده می‌شود:
   ```dockerfile
   CMD ["python", "app.py"]
   ```

#### روش 2: بدون Docker

1. ایجاد فایل `app.py` در روت
2. ایجاد پوشه `templates/` و قرار دادن `index.html`
3. ایجاد `requirements.txt`
4. Push به repository

### ⚙️ تنظیمات

در تب Settings:
- **Hardware**: CPU basic (رایگان)
- **Port**: 7860
- **Sleep Time**: 48 hours (برای free tier)

### 🔗 نتیجه
Space شما در آدرس زیر در دسترس خواهد بود:
```
https://huggingface.co/spaces/YOUR_USERNAME/YOUR_SPACE
```

---

## 2. Railway.app

### 🎯 مزایا
- ✅ Free tier سخاوتمندانه ($5 credit/month)
- ✅ Deploy خودکار از Git
- ✅ Custom domain رایگان
- ✅ Logs و Monitoring

### 📝 مراحل استقرار

1. **ثبت نام**
   - به [railway.app](https://railway.app) بروید
   - Sign up با GitHub

2. **Deploy از GitHub**
   ```bash
   # Push پروژه به GitHub
   git init
   git add .
   git commit -m "Initial commit"
   git push origin main
   ```

3. **ایجاد Project در Railway**
   - New Project
   - Deploy from GitHub repo
   - انتخاب repository

4. **تنظیمات (اختیاری)**
   ```bash
   # متغیرهای محیطی
   PORT=7860
   HOST=0.0.0.0
   ```

5. **Deploy**
   - Railway به صورت خودکار deploy می‌کند
   - URL عمومی دریافت می‌کنید

### 💰 هزینه
- Free tier: $5 credit/month (کافی برای این پروژه)
- پس از اتمام: $5-10/month

---

## 3. Render.com

### 🎯 مزایا
- ✅ Free tier
- ✅ راه‌اندازی ساده
- ✅ SSL رایگان
- ✅ Auto-deploy

### 📝 مراحل استقرار

1. **ثبت نام**
   - [render.com](https://render.com)

2. **New Web Service**
   - Connect GitHub repository
   - یا Manual Deploy

3. **تنظیمات**
   ```yaml
   Name: crypto-dashboard
   Environment: Python 3
   Build Command: pip install -r requirements.txt
   Start Command: python app.py
   ```

4. **Environment Variables**
   ```
   PORT=7860
   ```

5. **Deploy**
   - Create Web Service

### ⚠️ نکته
Free tier ممکن است پس از مدتی inactive شود (sleep mode)

---

## 4. Oracle Cloud (رایگان)

### 🎯 مزایا
- ✅ رایگان برای همیشه
- ✅ 2 VM instances
- ✅ 1GB RAM هر کدام
- ✅ 100GB storage

### 📝 مراحل استقرار

1. **ثبت نام در Oracle Cloud**
   - [cloud.oracle.com](https://cloud.oracle.com)
   - نیاز به کارت اعتباری (شارژ نمی‌شود)

2. **ایجاد VM Instance**
   - Compute > Instances > Create Instance
   - Shape: VM.Standard.E2.1.Micro (Free)
   - Image: Ubuntu 22.04

3. **نصب Python**
   ```bash
   ssh ubuntu@YOUR_VM_IP
   
   sudo apt update
   sudo apt install python3 python3-pip -y
   ```

4. **Deploy پروژه**
   ```bash
   # آپلود فایل‌ها
   scp -r crypto_dashboard ubuntu@YOUR_VM_IP:~/
   
   # SSH به سرور
   ssh ubuntu@YOUR_VM_IP
   
   cd crypto_dashboard
   pip3 install -r requirements.txt
   
   # اجرا
   python3 app.py
   ```

5. **نصب به عنوان Service**
   ```bash
   sudo nano /etc/systemd/system/crypto-dashboard.service
   ```
   
   محتوا:
   ```ini
   [Unit]
   Description=Crypto Dashboard
   After=network.target
   
   [Service]
   User=ubuntu
   WorkingDirectory=/home/ubuntu/crypto_dashboard
   ExecStart=/usr/bin/python3 /home/ubuntu/crypto_dashboard/app.py
   Restart=always
   
   [Install]
   WantedBy=multi-user.target
   ```
   
   فعال‌سازی:
   ```bash
   sudo systemctl enable crypto-dashboard
   sudo systemctl start crypto-dashboard
   ```

6. **باز کردن Port**
   - Networking > Virtual Cloud Networks
   - Security Lists > Add Ingress Rule
   - Port: 7860

### 🔗 دسترسی
```
http://YOUR_VM_IP:7860
```

---

## 5. Vercel

### 🎯 مزایا
- ✅ رایگان
- ✅ سریع
- ✅ Custom domain

### ⚠️ محدودیت
Vercel برای Serverless Functions طراحی شده، برای FastAPI نیاز به تنظیمات اضافی دارد.

### 📝 نیاز به:
1. ایجاد `vercel.json`
2. استفاده از `@vercel/python`
3. تبدیل به Serverless Functions

**توصیه**: برای این پروژه از Railway یا Render استفاده کنید.

---

## 6. Docker (محلی)

### 📝 مراحل

1. **Build Image**
   ```bash
   docker build -t crypto-dashboard .
   ```

2. **Run Container**
   ```bash
   docker run -p 7860:7860 crypto-dashboard
   ```

3. **با Docker Compose**
   
   ایجاد `docker-compose.yml`:
   ```yaml
   version: '3.8'
   services:
     crypto-dashboard:
       build: .
       ports:
         - "7860:7860"
       restart: always
   ```
   
   اجرا:
   ```bash
   docker-compose up -d
   ```

---

## 7. VPS / سرور اختصاصی

### 📝 مراحل (Ubuntu/Debian)

1. **نصب Dependencies**
   ```bash
   sudo apt update
   sudo apt install python3 python3-pip nginx -y
   ```

2. **آپلود پروژه**
   ```bash
   cd /opt
   sudo git clone YOUR_REPO
   cd crypto_dashboard
   sudo pip3 install -r requirements.txt
   ```

3. **ایجاد Systemd Service**
   ```bash
   sudo nano /etc/systemd/system/crypto-dashboard.service
   ```
   
   محتوا:
   ```ini
   [Unit]
   Description=Crypto Dashboard API
   After=network.target
   
   [Service]
   Type=simple
   User=www-data
   WorkingDirectory=/opt/crypto_dashboard
   ExecStart=/usr/bin/python3 /opt/crypto_dashboard/app.py
   Restart=always
   
   [Install]
   WantedBy=multi-user.target
   ```

4. **تنظیم Nginx (اختیاری)**
   ```nginx
   server {
       listen 80;
       server_name yourdomain.com;
       
       location / {
           proxy_pass http://127.0.0.1:7860;
           proxy_set_header Host $host;
           proxy_set_header X-Real-IP $remote_addr;
       }
   }
   ```

5. **فعال‌سازی**
   ```bash
   sudo systemctl enable crypto-dashboard
   sudo systemctl start crypto-dashboard
   sudo systemctl enable nginx
   sudo systemctl restart nginx
   ```

---

## 📊 مقایسه پلتفرم‌ها

| پلتفرم | رایگان | راحتی | سرعت | Custom Domain | مناسب برای |
|--------|--------|-------|------|---------------|-----------|
| **Hugging Face** | ✅ | ⭐⭐⭐⭐⭐ | ⭐⭐⭐ | ❌ | Demo, Testing |
| **Railway** | 💵 Limited | ⭐⭐⭐⭐⭐ | ⭐⭐⭐⭐ | ✅ | Production |
| **Render** | ✅ Limited | ⭐⭐⭐⭐ | ⭐⭐⭐ | ✅ | Production |
| **Oracle Cloud** | ✅ | ⭐⭐⭐ | ⭐⭐⭐⭐ | ✅ | Production |
| **VPS** | 💵 | ⭐⭐ | ⭐⭐⭐⭐⭐ | ✅ | Production |

---

## 🎯 توصیه بر اساس نیاز

### برای Demo و Testing**Hugging Face Spaces** 🏆

### برای Production با بودجه کم**Oracle Cloud** (رایگان) یا **Render.com**

### برای Production حرفه‌ای**Railway.app** یا **VPS**

### برای Maximum Performance**VPS اختصاصی** با Nginx

---

## 🔧 نکات عمومی

### SSL Certificate (HTTPS)
```bash
# با Certbot (Let's Encrypt)
sudo apt install certbot python3-certbot-nginx
sudo certbot --nginx -d yourdomain.com
```

### Monitoring
```bash
# لاگ‌ها
sudo journalctl -u crypto-dashboard -f

# وضعیت سرویس
sudo systemctl status crypto-dashboard
```

### Updates
```bash
cd crypto_dashboard
git pull
sudo systemctl restart crypto-dashboard
```

---

## ❓ سوالات متداول

**Q: چرا پس از deploy سایت کار نمی‌کند؟**
A: Port را چک کنید (باید 7860 باشد) و Logs را بررسی کنید

**Q: چگونه Custom Domain اضافه کنم؟**
A: در Settings پلتفرم خود، Custom Domain را تنظیم کنید

**Q: چرا سرعت کند است؟**
A: Cache را فعال کنید و CDN استفاده کنید

**Q: چگونه Database اضافه کنم؟**
A: SQLite (محلی) یا PostgreSQL (cloud) را اضافه کنید

---

## 📞 پشتیبانی

اگر در استقرار مشکل دارید:
1. Logs را بررسی کنید
2. Port و Firewall را چک کنید
3. Dependencies را دوباره نصب کنید
4. Issue باز کنید

**موفق باشید! 🚀**