optimize Makefile to direct build release package

pull/66/head
alimy 3 years ago
parent fcfcba9fc6
commit 1b349927ce

2
.gitignore vendored

@ -1,7 +1,7 @@
.idea .idea
.vscode .vscode
!*.example !*.example
dist/
config.yaml config.yaml
*.log *.log
paopao-ce* paopao-ce*
release/

@ -1,19 +1,66 @@
.PHONY: all build run test clean fmt help .PHONY: all build run test clean fmt help
TARGET = paopao-ce
RELEASE_ROOT = release
RELEASE_FILES = LICENSE README.md config.yaml.sample scripts assets configs
RELEASE_LINUX_AMD64 = $(RELEASE_ROOT)/linux-amd64/$(TARGET)
RELEASE_DARWIN_AMD64 = $(RELEASE_ROOT)/darwin-amd64/$(TARGET)
RELEASE_DARWIN_ARM64 = $(RELEASE_ROOT)/darwin-arm64/$(TARGET)
RELEASE_WINDOWS_AMD64 = $(RELEASE_ROOT)/windows-amd64/$(TARGET)
BUILD_VERSION := $(shell cat version) BUILD_VERSION := $(shell cat version)
BUILD_DATE := $(shell date +'%Y-%m-%d %H:%M:%S') BUILD_DATE := $(shell date +'%Y-%m-%d %H:%M:%S')
SHA_SHORT := $(shell git rev-parse --short HEAD) SHA_SHORT := $(shell git rev-parse --short HEAD)
TAGS = "" TAGS = ""
LDFLAGS = -X "main.version=${BUILD_VERSION}" -X "main.buildDate=${BUILD_DATE}" -X "main.commitID=${SHA_SHORT}" -w -s
all: fmt build all: fmt build
build: build:
@go mod download @go mod download
@echo Build paopao-ce @echo Build paopao-ce
bash build.sh paopao-ce @go build -trimpath -tags '$(TAGS)' -ldflags '$(LDFLAGS)' -o $(RELEASE_ROOT)/$(TARGET)
run: run:
@go run -tags '$(TAGS)' -ldflags "-X 'main.version=${BUILD_VERSION}' -X 'main.buildDate=${BUILD_DATE}' -X 'main.commitID=${SHA_SHORT}'" . @go run -trimpath -gcflags "all=-N -l" -tags '$(TAGS)' -ldflags '$(LDFLAGS)' .
.PHONY: release
release: linux-amd64 darwin-amd64 darwin-arm64 windows-x64
@echo Package paopao-ce
@cp -rf $(RELEASE_FILES) $(RELEASE_LINUX_AMD64)
@cp -rf $(RELEASE_FILES) $(RELEASE_DARWIN_AMD64)
@cp -rf $(RELEASE_FILES) $(RELEASE_DARWIN_ARM64)
@cp -rf $(RELEASE_FILES) $(RELEASE_WINDOWS_AMD64)
@cd $(RELEASE_LINUX_AMD64)/.. && rm -f *.zip && zip -r $(TARGET)-linux_amd64.zip $(TARGET) && cd -
@cd $(RELEASE_DARWIN_AMD64)/.. && rm -f *.zip && zip -r $(TARGET)-darwin_amd64.zip $(TARGET) && cd -
@cd $(RELEASE_DARWIN_ARM64)/.. && rm -f *.zip && zip -r $(TARGET)-darwin_arm64.zip $(TARGET) && cd -
@cd $(RELEASE_WINDOWS_AMD64)/.. && rm -f *.zip && zip -r $(TARGET)-windows_amd64.zip $(TARGET) && cd -
.PHONY: linux-amd64
linux-amd64:
@echo Build paopao-ce [linux-amd64]
@CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -trimpath -tags '$(TAGS)' -ldflags '$(LDFLAGS)' -o $(RELEASE_LINUX_AMD64)/$(TARGET)
.PHONY: darwin-amd64
darwin-amd64:
@echo Build paopao-ce [darwin-amd64]
@CGO_ENABLED=0 GOOS=darwin GOARCH=amd64 go build -trimpath -tags '$(TAGS)' -ldflags '$(LDFLAGS)' -o $(RELEASE_DARWIN_AMD64)/$(TARGET)
.PHONY: darwin-arm64
darwin-arm64:
@echo Build paopao-ce [darwin-arm64]
@CGO_ENABLED=0 GOOS=darwin GOARCH=arm64 go build -trimpath -tags '$(TAGS)' -ldflags '$(LDFLAGS)' -o $(RELEASE_DARWIN_ARM64)/$(TARGET)
.PHONY: windows-x64
windows-x64:
@echo Build paopao-ce [windows-x64]
@CGO_ENABLED=0 GOOS=windows GOARCH=amd64 go build -trimpath -tags '$(TAGS)' -ldflags '$(LDFLAGS)' -o $(RELEASE_WINDOWS_AMD64)/$(TARGET).exe
clean: clean:
@go clean @go clean
@find ./dist -type f -exec rm -r {} + @find ./release -type f -exec rm -r {} +
@find ./tmp -type f -exec rm -r {} +
fmt: fmt:
@echo Formatting... @echo Formatting...
@go fmt ./global/... @go fmt ./global/...
@ -22,14 +69,15 @@ fmt:
@go vet -composites=false ./global/... @go vet -composites=false ./global/...
@go vet -composites=false ./internal/... @go vet -composites=false ./internal/...
@go vet -composites=false ./pkg/... @go vet -composites=false ./pkg/...
test: test:
@go test ./... @go test ./...
help: help:
@echo "make: make" @echo "make: make"
@echo "make run: start api server" @echo "make run: start api server"
@echo "make build: build executables" @echo "make build: build executable with debug information"
@echo "make build: build executables" @echo "make release: build release executables"
@echo "make run TAGS='embed': start api server and serve embed web frontend" @echo "make run TAGS='embed': start api server and serve embed web frontend"
@echo "make build TAGS='embed': build executables with embed web frontend" @echo "make build TAGS='embed': build executable with embed web frontend"
.EXPORT_ALL_VARIABLES: @echo "make release TAGS='embed': build release executables with embed web frontend"
GO111MODULE = on

@ -84,7 +84,7 @@ PaoPao主要由以下优秀的开源项目/工具构建
#### 后端 #### 后端
1. 导入项目根目录下的 `paopao.sql` 文件至MySQL数据库 1. 导入项目根目录下的 `scripts/paopao.sql` 文件至MySQL数据库
2. 拷贝项目根目录下 `config.yaml.sample` 文件至 `config.yaml`,按照注释完成配置编辑 2. 拷贝项目根目录下 `config.yaml.sample` 文件至 `config.yaml`,按照注释完成配置编辑
3. 编译后端 3. 编译后端
编译api服务: 编译api服务:

@ -1,35 +0,0 @@
#!/usr/bin/env bash
# shellcheck disable=SC2155
set -e
DIST_PREFIX=${1}
DEBUG_MODE=${2}
TARGET_DIR="dist"
PLATFORMS="darwin/amd64 darwin/arm64 linux/amd64 windows/amd64"
rm -rf ${TARGET_DIR}
mkdir ${TARGET_DIR}
for pl in ${PLATFORMS}; do
export CGO_ENABLED=0
export GOOS=$(echo "${pl}" | cut -d'/' -f1)
export GOARCH=$(echo "${pl}" | cut -d'/' -f2)
export TARGET=${TARGET_DIR}/${DIST_PREFIX}_${GOOS}_${GOARCH}
if [ "${GOOS}" == "windows" ]; then
export TARGET=${TARGET_DIR}/${DIST_PREFIX}_${GOOS}_${GOARCH}.exe
fi
echo "build => ${TARGET}"
if [ "${DEBUG_MODE}" == "debug" ]; then
go build -trimpath -gcflags "all=-N -l" -o "${TARGET}" -tags "${TAGS}" \
-ldflags "-X 'main.version=${BUILD_VERSION}' \
-X 'main.buildDate=${BUILD_DATE}' \
-X 'main.commitID=${SHA_SHORT}'\
-w -s"
else
go build -trimpath -o "${TARGET}" -tags "${TAGS}" \
-ldflags "-X 'main.version=${BUILD_VERSION}' \
-X 'main.buildDate=${BUILD_DATE}' \
-X 'main.commitID=${SHA_SHORT}'\
-w -s"
fi
done

@ -0,0 +1 @@
All files in subdirectories are templates, do modifications based on your environment first.

@ -0,0 +1,32 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>info.paopao.web</string>
<!-- assumes running under 'paopao' account -->
<!-- modify below to reflect your settings -->
<key>UserName</key>
<string>paopao</string>
<key>GroupName</key>
<string>paopao</string>
<key>ProgramArguments</key>
<array>
<!-- assumes installed in /Users/paopao/app -->
<!-- modify below to reflect your settings -->
<string>/Users/paopao/app/paopao-ce</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>KeepAlive</key>
<true/>
<!-- assumes Gogs is installed in /Users/git/gogs -->
<!-- modify below to reflect your settings -->
<key>WorkingDirectory</key>
<string>/Users/paopao/app/</string>
<key>StandardOutPath</key>
<string>/Users/paopao/app/log/stdout.log</string>
<key>StandardErrorPath</key>
<string>/Users/paopao/app/log/stderr.log</string>
</dict>
</plist>

@ -0,0 +1,17 @@
[Unit]
Description=paopao-ce
After=syslog.target
After=network.target
After=mariadb.service mysqld.service redis.service
[Service]
Type=simple
User=paopao
Group=paopao
WorkingDirectory=/home/paopao/app
ExecStart=/home/paopao/app/paopao-ce
Restart=always
Environment=USER=paopao HOME=/home/paopao
[Install]
WantedBy=multi-user.target
Loading…
Cancel
Save