Я нашел решение, включающее всего 2 сборки. Но теперь необходимо запустить 2 экземпляра серверного процесса.
Шаг # 1: angular. json
Убедитесь, что ваши локали правильно определены в angular.json
и добавьте новый allLocales
target в my-project:server
option.
Я создал новую allLocales
target, потому что я не знал, как объединить production
target с en
и fr
конфигурациями. Смысл этого заключается в том, чтобы иметь только одну сборку сервера со всеми созданными языковыми серверами.
Для передней связки это возможно с помощью ng build
(то есть ng build --configuration=production,fr,en or ng build --configuration=production --localize
)
angular. json
"projects": {
"my-project": {
"i18n": {
"locales": {
"en": {
"translation": "src/locale/messages.en.xlf",
"baseHref": ""
},
"fr": {
"translation": "src/locale/messages.fr.xlf",
"baseHref": ""
}
}
},
"root": "",
"sourceRoot": "src",
"projectType": "application",
"architect": {
"build": {
"builder": "@angular-devkit/build-angular:browser",
"options": {
//...
},
"configurations": {
"production": {
//...
},
"en": {
"localize": [
"en"
]
},
"fr": {
"localize": [
"fr"
]
}
}
},
"server": {
"builder": "@angular-devkit/build-angular:server",
"options": {
"outputPath": "dist/my-project/server",
"main": "server.ts",
"tsConfig": "tsconfig.server.json"
},
"configurations": {
"production": {
//...
},
"allLocales": {
"outputHashing": "none",
"optimization": false,
"sourceMap": false,
"namedChunks": false,
"extractLicenses": true,
"vendorChunk": false,
"localize": [
"en", "fr"
],
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.prod.ts"
}
]
}
}
},
Шаг № 2: server.ts
Измените файл server.ts
, чтобы принять языковой параметр. Каждый работающий сервер сгенерированного серверного комплекта main.js
будет иметь свой собственный порт и язык.
server.ts
//...
export function app(language) { //add language here
const server = express();
const distFolder = join(process.cwd(), 'dist/my-project/browser', language); //Use language here
//...
function run() {
const port = process.env.PORT || 5006;
const language = process.env.LANGUAGE || 'fr';
// Start up the Node server
const server = app(language); //Use the language here
server.listen(port, () => {
console.log(`Node Express server listening on http://localhost:${port} for language ${language}`);
});
Шаг № 3: Изменить пакет. json
пакет. json
"build:ssr": "ng build -c production --localize && ng run my-project:server:allLocales"
"serve:ssr-en": "env PORT=5006 LANGUAGE=en node dist/my-project/server/en/main.js",
"serve:ssr-fr": "env PORT=5007 LANGUAGE=fr node dist/my-project/server/fr/main.js",
build:ssr
создаст клиентские пакеты для всех языков, а затем создаст серверные пакеты для всех языков server:ssr-XX
запустит сервер nodejs для порта и языка, связанных с языком XX
Вот структура
- dist
- myproject
- browser
- fr
- index.html
- *.js
- en
- index.html
- *.js
- server
- fr
- main.js
- en
- main.js
Шаг 4: Обратный прокси
Если вы используете обратный прокси-сервер, не забудьте перенаправить все запросы на правильный основной. js экземпляр
Примечание Процесс сборки теперь намного быстрее с angular 9, так как есть только 2 билда.