1. 程式人生 > >git 實現提交遠端分支步驟

git 實現提交遠端分支步驟

git clone 
git branch [分支名] 建立分支
git branch 檢視本地所有分支
git checkout [分支名稱] 切換分支
---寫程式碼---
git status (檢視檔案改變記錄)
git diff (檢視程式碼級改變)
git add (1:確認改變)
git commit -m 提交註釋 (2:提交到當前分支的本地工作區)
git push [遠端分支:origin] [本地分支的名稱]
去git 管理網站建立Merge Request
等待合併
----管理員合併所有人的Merge Request----
checkout master (切換至Master)
git pull (從遠端master 更新至 本地master)
checkout [branch] (切換至本地分支)
git rebase master [從本地 master 更新當前分支]
----是否有衝突---- ----有---- 1. 在git平臺建立工程 1) 建立私有專案庫 2)克隆專案到本地 git clone https://gitee.com/fynihao/meiduo3.git git config --global user.email [email protected] git config --global user.name "xxxx" 3)建立並切換分支到dev git checkout -b dev 2. 新增前端檔案 在meiduo目錄中建立前端檔案子目錄front_end_pc 將前端靜態附件複製到front_end_pc目錄下 git提交 git add front_end_pc git status git commit
-m 'add front end files' 推送到遠端 git push origin dev:dev 前端檔案開發預覽 可以使用前端node.js 提供的伺服器作為前端開發伺服器使用。 安裝 npm install -g live-server 使用 # 在靜態檔案目錄front_end_pc下執行 live-server live-server執行在8080埠下,可以通過127.0.0.1:8080來訪問靜態頁面。 3. 建立Django REST framework工程 參考框架階段學習的知識,建立虛擬環境,並建立Django REST framework工程。 工程目錄調整如下: •apps 存放Django的應用 •libs 存放第三方的庫檔案 •settings 存放配置檔案的目錄,分為開發dev和線上prod •utils 存放專案自己定義的公共函式或類等 •docs 用於存放一些說明文件資料 •scripts 用於存放管理指令碼檔案
4. 建立資料庫 create database meiduo_mall default charset=utf8; 為本專案建立資料庫使用者 二.配置 1. 修改settings/dev.py 檔案中的路徑資訊 我們將Django的應用放到了 工程目錄/meiduo_mall/apps目錄下,如果建立一個應用,比如users,那麼在配置檔案的INSTALLED_APPS中註冊應用應該如下: INSTALLED_APPS = [ ... 'meiduo_mall.apps.users.apps.UsersConfig', ] 為了還能像如下方式簡便的註冊引用,我們需要向Python直譯器的導包路徑中新增apps應用目錄的路徑。 INSTALLED_APPS = [ ... 'users.apps.UsersConfig', ] 我們將配置檔案改為放在settings子目錄下,所以 配置檔案中的BASE_DIR指向的變為了工程目錄/meiduo_mall/meiduo_mall。 使用sys.path新增<BASE_DIR>/apps目錄,即可新增apps應用的導包路徑。 # Build paths inside the project like this: os.path.join(BASE_DIR, ...) BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) # 新增導包路徑 import sys sys.path.insert(0, os.path.join(BASE_DIR, 'apps')) 2. INSTALLED_APPS 在INSTALLED_APPS中新增rest_framework INSTALLED_APPS = [ ... 'rest_framework', ] 3. 資料庫 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'HOST': '127.0.0.1', # 資料庫主機 'PORT': 3306, # 資料庫埠 'USER': 'root', # 資料庫使用者名稱 'PASSWORD': '', # 資料庫使用者密碼 'NAME': 'meiduo' # 資料庫名字 } } 注意: 記得在工程目錄/meiduo_mall/__init__.py檔案中新增 import pymysql pymysql.install_as_MySQLdb() 4. Redis 安裝django-redis,並配置 CACHES = { "default": { "BACKEND": "django_redis.cache.RedisCache", "LOCATION": "redis://127.0.0.1:6379/0", "OPTIONS": { "CLIENT_CLASS": "django_redis.client.DefaultClient", } }, "session": { "BACKEND": "django_redis.cache.RedisCache", "LOCATION": "redis://127.0.0.1:6379/1", "OPTIONS": { "CLIENT_CLASS": "django_redis.client.DefaultClient", } } } SESSION_ENGINE = "django.contrib.sessions.backends.cache" SESSION_CACHE_ALIAS = "session" 除了名為default的redis配置外,還補充了名為session的redis配置,分別使用兩個不同的redis庫。 同時修改了Django的Session機制使用redis儲存,且使用名為'session'的redis配置。 此處修改Django的Session機制儲存主要是為了給Admin站點使用。 關於django-redis 的使用,說明文件可見http://django-redis-chs.readthedocs.io/zh_CN/latest/ 5. 本地化語言與時區 LANGUAGE_CODE = 'zh-hans' TIME_ZONE = 'Asia/Shanghai' 6. 日誌 LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'formatters': { 'verbose': { 'format': '%(levelname)s %(asctime)s %(module)s %(lineno)d %(message)s' }, 'simple': { 'format': '%(levelname)s %(module)s %(lineno)d %(message)s' }, }, 'filters': { 'require_debug_true': { '()': 'django.utils.log.RequireDebugTrue', }, }, 'handlers': { 'console': { 'level': 'DEBUG', 'filters': ['require_debug_true'], 'class': 'logging.StreamHandler', 'formatter': 'simple' }, 'file': { 'level': 'INFO', 'class': 'logging.handlers.RotatingFileHandler', 'filename': os.path.join(os.path.dirname(BASE_DIR), "logs/meiduo.log"), # 日誌檔案的位置 'maxBytes': 300 * 1024 * 1024, 'backupCount': 10, 'formatter': 'verbose' }, }, 'loggers': { 'django': { # 定義了一個名為django的日誌器 'handlers': ['console', 'file'], 'propagate': True, }, } } 7. 異常處理 修改Django REST framework的預設異常處理方法,補充處理資料庫異常和Redis異常。 新建utils/exceptions.py from rest_framework.views import exception_handler as drf_exception_handler import logging from django.db import DatabaseError from redis.exceptions import RedisError from rest_framework.response import Response from rest_framework import status # 獲取在配置檔案中定義的logger,用來記錄日誌 logger = logging.getLogger('django') def exception_handler(exc, context): """ 自定義異常處理 :param exc: 異常 :param context: 丟擲異常的上下文 :return: Response響應物件 """ # 呼叫drf框架原生的異常處理方法 response = drf_exception_handler(exc, context) if response is None: view = context['view'] if isinstance(exc, DatabaseError) or isinstance(exc, RedisError): # 資料庫異常 logger.error('[%s] %s' % (view, exc)) response = Response({'message': '伺服器內部錯誤'}, status=status.HTTP_507_INSUFFICIENT_STORAGE) return response 配置檔案中新增 REST_FRAMEWORK = { # 異常處理 'EXCEPTION_HANDLER': 'meiduo_mall.utils.exceptions.exception_handler', }