mirror of
				https://github.com/containous/traefik.git
				synced 2025-10-25 03:33:20 +03:00 
			
		
		
		
	Compare commits
	
		
			428 Commits
		
	
	
		
			v2.6.7
			...
			v3.0.0-bet
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 52d2d959af | ||
|  | 0a35fa096a | ||
|  | a7ef965412 | ||
|  | 0a861716d4 | ||
|  | 4fbe9b81ec | ||
|  | 5fd6913ee5 | ||
|  | 7741c68eaa | ||
|  | 18077ff69a | ||
|  | fa555d0d29 | ||
|  | 0e5898b2f8 | ||
|  | aae76408e2 | ||
|  | 9cc9ed6a0c | ||
|  | fecaec7a4a | ||
|  | e62fe64ec9 | ||
|  | 6885e410f0 | ||
|  | 68ed875966 | ||
|  | d1bdeb3a92 | ||
|  | 878e7de56a | ||
|  | 27353d0740 | ||
|  | 606281a4a5 | ||
|  | c5f23493ab | ||
|  | db515195f0 | ||
|  | 9aa57f362b | ||
|  | 6977b68b72 | ||
|  | 8d8717d421 | ||
|  | 981ad74870 | ||
|  | 021f37ff71 | ||
|  | 511762cbf3 | ||
|  | 466d7461b7 | ||
|  | 1522afe2ec | ||
|  | 9c73c4c584 | ||
|  | 8f206ce319 | ||
|  | 65c59c9a09 | ||
|  | e044e2b765 | ||
|  | 7805c683e3 | ||
|  | e38c0c3969 | ||
|  | 2cebd0a083 | ||
|  | c0e03ae17d | ||
|  | 9060522414 | ||
|  | bb4eb32b1c | ||
|  | 30f991effa | ||
|  | fc071a5ebe | ||
|  | 6082b22922 | ||
|  | 5635687a3e | ||
|  | a3f1009170 | ||
|  | 79c5f34156 | ||
|  | 928db9bc42 | ||
|  | c4bea197ab | ||
|  | e8878fe6ac | ||
|  | f344239bef | ||
|  | 4ed3964b35 | ||
|  | 11966c2098 | ||
|  | 0d1bb72306 | ||
|  | 4c9765b52d | ||
|  | 5f514b0d16 | ||
|  | 01f346f239 | ||
|  | be1b1a6489 | ||
|  | ae65d5ff78 | ||
|  | 7fc07c31a0 | ||
|  | f2eda3aa6d | ||
|  | ac9d88e5a2 | ||
|  | 598caf6f78 | ||
|  | 77509b0913 | ||
|  | 8b47c5adf7 | ||
|  | a3bcf0f39e | ||
|  | be702c2b61 | ||
|  | 54f6144ef2 | ||
|  | a020ab640d | ||
|  | 7875826bd9 | ||
|  | f7be1e97df | ||
|  | 48a2c8e41c | ||
|  | 358f47443e | ||
|  | 3b9e155807 | ||
|  | 2083e4bc16 | ||
|  | c823879097 | ||
|  | 4bc2305ed3 | ||
|  | 99d779a546 | ||
|  | 6e460cd652 | ||
|  | 7c2af10bbd | ||
|  | 7af9d16208 | ||
|  | 598a257ae1 | ||
|  | b3f162a8a6 | ||
|  | 4aa3496092 | ||
|  | bbe6a5c07b | ||
|  | 20e47d9102 | ||
|  | 21c455cf20 | ||
|  | 667b2a4078 | ||
|  | 4ae07d91a4 | ||
|  | 7bdf13ebdc | ||
|  | 807feef176 | ||
|  | 7202038649 | ||
|  | dd710dbeb7 | ||
|  | f26e250648 | ||
|  | 80790cba17 | ||
|  | 2e6e5cbd03 | ||
|  | 241fb5093a | ||
|  | ab36ea7844 | ||
|  | cfef9d9df2 | ||
|  | 9ce69fbdef | ||
|  | 1a6dfe1f6b | ||
|  | e053eb6f17 | ||
|  | 780936eff9 | ||
|  | 0503253cfe | ||
|  | 39331e41a8 | ||
|  | 044dc6a221 | ||
|  | 38f5024ed0 | ||
|  | 479878503d | ||
|  | 6f6c1f7fec | ||
|  | e50bf21a84 | ||
|  | d66875f903 | ||
|  | 707f84e2e4 | ||
|  | f94298e867 | ||
|  | b995a11d63 | ||
|  | e1abf103c0 | ||
|  | f01a668d53 | ||
|  | 8cd4923e72 | ||
|  | cd90b9761a | ||
|  | e82976e001 | ||
|  | f0f5f41fb9 | ||
|  | c9e9e8dee2 | ||
|  | 0861c47e54 | ||
|  | 8bf68b7efd | ||
|  | e1e86763e3 | ||
|  | b22aef7fff | ||
|  | b9a175f5c2 | ||
|  | a2016a2953 | ||
|  | c38d405cfd | ||
|  | 8c98234c07 | ||
|  | d046af2e91 | ||
|  | 943238faba | ||
|  | 2b67f1f66f | ||
|  | 943811fad6 | ||
|  | 2ad1fd725a | ||
|  | 7129f03dc9 | ||
|  | 29b8b6911e | ||
|  | e7baf44a2e | ||
|  | 74ef79ea23 | ||
|  | 748254b6c5 | ||
|  | a08a428787 | ||
|  | 3eeea2bb2b | ||
|  | da93dab828 | ||
|  | c2dac39da1 | ||
|  | e54ee89330 | ||
|  | fdd3f2abef | ||
|  | 517917cd7c | ||
|  | d97d3a6726 | ||
|  | 6c75052a13 | ||
|  | a8df674dcf | ||
|  | abd569701f | ||
|  | 7e3fe48b80 | ||
|  | 8cf9385938 | ||
|  | 519ed8bde5 | ||
|  | 46a61ce9c8 | ||
|  | 778188ed34 | ||
|  | 88603810a8 | ||
|  | c7647b4938 | ||
|  | af71443b61 | ||
|  | c57876c116 | ||
|  | 0d81fac3fc | ||
|  | db287c4d31 | ||
|  | 4d86668af3 | ||
|  | b93141992e | ||
|  | 18d66d7432 | ||
|  | a3e4c85ec0 | ||
|  | bee86b5ac7 | ||
|  | 0ba51d62fa | ||
|  | 268d1edc8f | ||
|  | 580e7fa774 | ||
|  | 7c72780820 | ||
|  | 46c266661c | ||
|  | 61325d7b91 | ||
|  | 68e8eb2435 | ||
|  | 3f8aa13e68 | ||
|  | 08279047ae | ||
|  | 3dd4968c41 | ||
|  | ba1ca68977 | ||
|  | 81a5b1b4c8 | ||
|  | 52e6ce95cf | ||
|  | d547718fdd | ||
|  | 56f7515ecd | ||
|  | af4e74c39d | ||
|  | 27c02b5a56 | ||
|  | f6b7940b76 | ||
|  | f1b91a119d | ||
|  | 630de7481e | ||
|  | fadee5e87b | ||
|  | 35d8281f4d | ||
|  | 67d9c8da0b | ||
|  | 00de5c711a | ||
|  | b935c80dbd | ||
|  | 22c6630412 | ||
|  | 1a1cfd1adc | ||
|  | 240fb871b6 | ||
|  | b2c4221429 | ||
|  | d131ef57da | ||
|  | 97de552e06 | ||
|  | 281fa25844 | ||
|  | 454f552691 | ||
|  | 7258048403 | ||
|  | bd3eaf4f5e | ||
|  | 15f7472091 | ||
|  | a041a6b198 | ||
|  | 7582da9650 | ||
|  | 7a6bfd3336 | ||
|  | 1b9873cae9 | ||
|  | e86f21ae7b | ||
|  | ccbbd0d766 | ||
|  | 93212125e3 | ||
|  | be3b798dd6 | ||
|  | 8128d6ca26 | ||
|  | 194247caae | ||
|  | cd0654026a | ||
|  | 14ab1514dc | ||
|  | 40242294d8 | ||
|  | 996eccf5b7 | ||
|  | b39ce8cc58 | ||
|  | e9de061b84 | ||
|  | 33f0aed5ea | ||
|  | 0ca1c8aac3 | ||
|  | 2c550c284d | ||
|  | 87815586be | ||
|  | 09d6383621 | ||
|  | 188ef84c4f | ||
|  | a5c520664a | ||
|  | 39b0077725 | ||
|  | e2a9caf760 | ||
|  | bc79796c38 | ||
|  | b1db81d8ac | ||
|  | 38d7011487 | ||
|  | ae7db879d9 | ||
|  | dd34905ea9 | ||
|  | 3812e6f3cb | ||
|  | 627175694d | ||
|  | 82cf6c9577 | ||
|  | 63a1186d3e | ||
|  | f75f636e27 | ||
|  | 615dc7fd35 | ||
|  | 52b6b057f0 | ||
|  | 7b3faef4b3 | ||
|  | 7758880f3f | ||
|  | d04903edb2 | ||
|  | a63d5c95a8 | ||
|  | bb66950197 | ||
|  | c4cc30ccc6 | ||
|  | 9cd54baca4 | ||
|  | 7ac687a0a9 | ||
|  | 83ae1021f6 | ||
|  | 033fccccc7 | ||
|  | df99a9fb57 | ||
|  | 67e3bc6380 | ||
|  | d6b69e1347 | ||
|  | 4bd055cf97 | ||
|  | 4b291b2cf8 | ||
|  | 89870ad539 | ||
|  | 5bc03af75f | ||
|  | 30ec5c58fe | ||
|  | a4b447256b | ||
|  | 1c9a7b8c61 | ||
|  | d06573de6c | ||
|  | 6c2c561d8f | ||
|  | e5309a4601 | ||
|  | e9f98fb6eb | ||
|  | b351266b2d | ||
|  | fd95560c66 | ||
|  | 788f8fa951 | ||
|  | 89dc466b23 | ||
|  | ab8d7d2e78 | ||
|  | a002ccfce3 | ||
|  | 693d5da1b9 | ||
|  | 8ddc37d528 | ||
|  | 0cb2652f51 | ||
|  | fe8e7ab5b8 | ||
|  | d531963f95 | ||
|  | d578ed7327 | ||
|  | 10528c973a | ||
|  | 56a1ed4220 | ||
|  | 37b6edb28c | ||
|  | 44a2b85dba | ||
|  | 77c8d60092 | ||
|  | b33c8cec0b | ||
|  | 52df1d63fe | ||
|  | c84378d649 | ||
|  | 12dccc4fdd | ||
|  | 32e44816c9 | ||
|  | 23c74c9f2e | ||
|  | 9a82d96e68 | ||
|  | d9589878fb | ||
|  | 703de5331b | ||
|  | d3e4d56a0d | ||
|  | adf82d72ae | ||
|  | 25027d6df8 | ||
|  | e56dfeb7d5 | ||
|  | 5ca7fff7f6 | ||
|  | dfa1f3fc00 | ||
|  | b26c45af2b | ||
|  | 626da4c0ae | ||
|  | 9c02612f65 | ||
|  | b3f4f6bb21 | ||
|  | 2cac58d9c0 | ||
|  | a553085689 | ||
|  | 6dd63e1702 | ||
|  | 868ab7a5c8 | ||
|  | 23c26d64ee | ||
|  | 63f9ec9c38 | ||
|  | 40db06204b | ||
|  | 4755bb2f33 | ||
|  | 45453b20fa | ||
|  | 40d2421db9 | ||
|  | af749f1864 | ||
|  | 1576ad85b8 | ||
|  | 2a2ea759d1 | ||
|  | b4ee7bdcbe | ||
|  | 146991efda | ||
|  | ab94bbaece | ||
|  | 5a706296f2 | ||
|  | 5b3354b8ce | ||
|  | 7751fb24eb | ||
|  | f85f3b68aa | ||
|  | b361608693 | ||
|  | cdda9a18ab | ||
|  | 3686f95832 | ||
|  | 2cb011f595 | ||
|  | b7199a7a9b | ||
|  | 14eb56cf30 | ||
|  | ff2911d070 | ||
|  | f07fcd3d54 | ||
|  | 0e4b4c1a31 | ||
|  | 154d8470ab | ||
|  | c9520480c2 | ||
|  | 05c3486347 | ||
|  | 0231db05b4 | ||
|  | 4dc379c601 | ||
|  | 8f6463ba7a | ||
|  | aff334ffb4 | ||
|  | 28da781194 | ||
|  | 51a02caea3 | ||
|  | 839bc7b3a8 | ||
|  | 9c79fafeeb | ||
|  | c51e590591 | ||
|  | 9c4b336f3b | ||
|  | aa8fda5eae | ||
|  | 8b22101236 | ||
|  | 3c1d5e0393 | ||
|  | 03598d395b | ||
|  | 9d61cb64a2 | ||
|  | ba3f5b318c | ||
|  | 62e17c659e | ||
|  | 41748c3ae4 | ||
|  | 65a317010b | ||
|  | a887794313 | ||
|  | 77e1ce2877 | ||
|  | 470a4f6e5f | ||
|  | 94141233f0 | ||
|  | 467c8b31c3 | ||
|  | ff17ac53df | ||
|  | 55ba4356f2 | ||
|  | 804b0ff2f2 | ||
|  | 818541d4d7 | ||
|  | 1b199730d2 | ||
|  | f8f685193d | ||
|  | 6e535f8cef | ||
|  | 23340c46e6 | ||
|  | 5c15f5fe04 | ||
|  | ba7e9ed788 | ||
|  | 9ccc8cfb25 | ||
|  | 9810bde68b | ||
|  | 251798a778 | ||
|  | 91f4ccf087 | ||
|  | 73306a1533 | ||
|  | b3eb629785 | ||
|  | aa0b5466a9 | ||
|  | becee5e393 | ||
|  | 59e66dfce5 | ||
|  | 9c59df5e9c | ||
|  | 2a88b25712 | ||
|  | b952f814c1 | ||
|  | f90e3817e8 | ||
|  | 6d6f8b28d7 | ||
|  | 118d56fc40 | ||
|  | f352c34136 | ||
|  | fbf90e6981 | ||
|  | 607faace07 | ||
|  | 521109d3f2 | ||
|  | ec25bdb9f9 | ||
|  | 685962545a | ||
|  | 34d29e7a10 | ||
|  | 05f3e60366 | ||
|  | ac4086d0ac | ||
|  | d5ff301d90 | ||
|  | ede2be1f66 | ||
|  | 86cc6df374 | ||
|  | ae6e844143 | ||
|  | 619621f239 | ||
|  | 7d274e8088 | ||
|  | 707d355d4a | ||
|  | 73ba7ed2d2 | ||
|  | 883422dc21 | ||
|  | 71150bcaaf | ||
|  | 8c56d1a338 | ||
|  | a49b537d9c | ||
|  | 45328ab719 | ||
|  | 0d7d5a0318 | ||
|  | c0b0f3f0f7 | ||
|  | a4560fa20d | ||
|  | fbdb6e6e78 | ||
|  | 8d58f33a28 | ||
|  | d2a2362be5 | ||
|  | 4c0a3721d0 | ||
|  | 3bf4a8fbe2 | ||
|  | 2da7fa0397 | ||
|  | 0d58e8d1ad | ||
|  | dad76e0478 | ||
|  | 79aab5aab8 | ||
|  | 6622027c7c | ||
|  | 401c171bbd | ||
|  | 63bb770b9c | ||
|  | c7b24f4e9c | ||
|  | 25725e9b2f | ||
|  | aaf5aa4506 | ||
|  | 9297055ad8 | ||
|  | a79868fadc | ||
|  | ca55dfe1c6 | ||
|  | 5780dc2b15 | ||
|  | 764bf59d4d | ||
|  | 7543709ecf | ||
|  | 1048348ae6 | ||
|  | ba822acb23 | ||
|  | f5dd233a3b | 
							
								
								
									
										8
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							| @@ -6,12 +6,14 @@ body: | ||||
|     attributes: | ||||
|       label: Welcome! | ||||
|       description: | | ||||
|         The issue tracker is for reporting bugs and feature requests only. For end-user related support questions, please refer to one of the following: | ||||
|         - the Traefik community forum: https://community.traefik.io/ | ||||
|         The issue tracker is for reporting bugs and feature requests only. | ||||
|         For end-user related support questions, please use the [Traefik community forum](https://community.traefik.io/). | ||||
|  | ||||
|         The configurations between 1.X and 2.X are NOT compatible. Please have a look [here](https://doc.traefik.io/traefik/getting-started/configuration-overview/). | ||||
|         All new/updated issues are triaged regularly by the maintainers. | ||||
|         All issues closed by a bot are subsequently double-checked by the maintainers. | ||||
|  | ||||
|         DO NOT FILE ISSUES FOR GENERAL SUPPORT QUESTIONS. | ||||
|  | ||||
|       options: | ||||
|         - label: Yes, I've searched similar issues on [GitHub](https://github.com/traefik/traefik/issues) and didn't find any. | ||||
|           required: true | ||||
|   | ||||
							
								
								
									
										12
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							| @@ -2,16 +2,16 @@ | ||||
| PLEASE READ THIS MESSAGE. | ||||
|  | ||||
| Documentation fixes or enhancements: | ||||
| - for Traefik v1: use branch v1.7 | ||||
| - for Traefik v2: use branch v2.6 | ||||
| - for Traefik v2: use branch v2.10 | ||||
| - for Traefik v3: use branch v3.0 | ||||
|  | ||||
| Bug fixes: | ||||
| - for Traefik v1: use branch v1.7 | ||||
| - for Traefik v2: use branch v2.6 | ||||
| - for Traefik v2: use branch v2.10 | ||||
| - for Traefik v3: use branch v3.0 | ||||
|  | ||||
| Enhancements: | ||||
| - for Traefik v1: we only accept bug fixes | ||||
| - for Traefik v2: use branch master | ||||
| - for Traefik v2: we only accept bug fixes | ||||
| - for Traefik v3: use branch master | ||||
|  | ||||
| HOW TO WRITE A GOOD PULL REQUEST? https://doc.traefik.io/traefik/contributing/submitting-pull-requests/ | ||||
|  | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/workflows/build.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/build.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -6,7 +6,7 @@ on: | ||||
|       - '*' | ||||
|  | ||||
| env: | ||||
|   GO_VERSION: 1.17 | ||||
|   GO_VERSION: '1.20' | ||||
|   CGO_ENABLED: 0 | ||||
|   IN_DOCKER: "" | ||||
|  | ||||
| @@ -56,7 +56,7 @@ jobs: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - name: Cache Go modules | ||||
|         uses: actions/cache@v2 | ||||
|         uses: actions/cache@v3 | ||||
|         with: | ||||
|           path: | | ||||
|             ~/go/pkg/mod | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/workflows/check_doc.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/check_doc.yml
									
									
									
									
										vendored
									
									
								
							| @@ -19,3 +19,7 @@ jobs: | ||||
|  | ||||
|       - name: Check documentation | ||||
|         run: make docs-pull-images docs | ||||
|         env: | ||||
|           # These variables are not passed to workflows that are triggered by a pull request from a fork. | ||||
|           DOCS_VERIFY_SKIP: ${{ vars.DOCS_VERIFY_SKIP }} | ||||
|           DOCS_LINT_SKIP: ${{ vars.DOCS_LINT_SKIP }} | ||||
|   | ||||
							
								
								
									
										6
									
								
								.github/workflows/documentation.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/documentation.yml
									
									
									
									
										vendored
									
									
								
							| @@ -7,7 +7,7 @@ on: | ||||
|       - v* | ||||
|  | ||||
| env: | ||||
|   STRUCTOR_VERSION: v1.11.2 | ||||
|   STRUCTOR_VERSION: v1.13.2 | ||||
|   MIXTUS_VERSION: v0.4.1 | ||||
|  | ||||
| jobs: | ||||
| @@ -41,12 +41,12 @@ jobs: | ||||
|       - name: Build documentation | ||||
|         run: $HOME/bin/structor -o traefik -r traefik --dockerfile-url="https://raw.githubusercontent.com/traefik/traefik/v1.7/docs.Dockerfile" --menu.js-url="https://raw.githubusercontent.com/traefik/structor/master/traefik-menu.js.gotmpl" --rqts-url="https://raw.githubusercontent.com/traefik/structor/master/requirements-override.txt" --force-edit-url --exp-branch=master --debug | ||||
|         env: | ||||
|           STRUCTOR_LATEST_TAG: ${{ secrets.STRUCTOR_LATEST_TAG }} | ||||
|           STRUCTOR_LATEST_TAG: ${{ vars.STRUCTOR_LATEST_TAG }} | ||||
|  | ||||
|       - name: Apply seo | ||||
|         run: $HOME/bin/seo -path=./site -product=traefik | ||||
|  | ||||
|       - name: Publish documentation | ||||
|         run: $HOME/bin/mixtus --dst-doc-path="./traefik" --dst-owner=traefik --dst-repo-name=doc --git-user-email="30906710+traefiker@users.noreply.github.com" --git-user-name=traefiker --src-doc-path="./site" --src-owner=containous --src-repo-name=traefik | ||||
|         run: $HOME/bin/mixtus --dst-doc-path="./traefik" --dst-owner=traefik --dst-repo-name=doc --git-user-email="30906710+traefiker@users.noreply.github.com" --git-user-name=traefiker --src-doc-path="./site" --src-owner=traefik --src-repo-name=traefik | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GH_TOKEN_REPO }} | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/workflows/test-unit.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/test-unit.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -6,7 +6,7 @@ on: | ||||
|       - '*' | ||||
|  | ||||
| env: | ||||
|   GO_VERSION: 1.17 | ||||
|   GO_VERSION: '1.20' | ||||
|   IN_DOCKER: "" | ||||
|  | ||||
| jobs: | ||||
| @@ -31,7 +31,7 @@ jobs: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - name: Cache Go modules | ||||
|         uses: actions/cache@v2 | ||||
|         uses: actions/cache@v3 | ||||
|         with: | ||||
|           path: | | ||||
|             ~/go/pkg/mod | ||||
|   | ||||
							
								
								
									
										12
									
								
								.github/workflows/validate.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								.github/workflows/validate.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -6,9 +6,9 @@ on: | ||||
|       - '*' | ||||
|  | ||||
| env: | ||||
|   GO_VERSION: 1.17 | ||||
|   GOLANGCI_LINT_VERSION: v1.46.2 | ||||
|   MISSSPELL_VERSION: v0.3.4 | ||||
|   GO_VERSION: '1.20' | ||||
|   GOLANGCI_LINT_VERSION: v1.53.1 | ||||
|   MISSSPELL_VERSION: v0.4.0 | ||||
|   IN_DOCKER: "" | ||||
|  | ||||
| jobs: | ||||
| @@ -33,7 +33,7 @@ jobs: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - name: Cache Go modules | ||||
|         uses: actions/cache@v2 | ||||
|         uses: actions/cache@v3 | ||||
|         with: | ||||
|           path: | | ||||
|             ~/go/pkg/mod | ||||
| @@ -45,7 +45,7 @@ jobs: | ||||
|         run: curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin ${GOLANGCI_LINT_VERSION} | ||||
|  | ||||
|       - name: Install missspell ${{ env.MISSSPELL_VERSION }} | ||||
|         run: curl -sfL https://raw.githubusercontent.com/client9/misspell/master/install-misspell.sh | sh -s -- -b $(go env GOPATH)/bin ${MISSSPELL_VERSION} | ||||
|         run: curl -sfL https://raw.githubusercontent.com/golangci/misspell/master/install-misspell.sh | sh -s -- -b $(go env GOPATH)/bin ${MISSSPELL_VERSION} | ||||
|  | ||||
|       - name: Avoid generating webui | ||||
|         run: touch webui/static/index.html | ||||
| @@ -73,7 +73,7 @@ jobs: | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       - name: Cache Go modules | ||||
|         uses: actions/cache@v2 | ||||
|         uses: actions/cache@v3 | ||||
|         with: | ||||
|           path: | | ||||
|             ~/go/pkg/mod | ||||
|   | ||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -18,3 +18,4 @@ vendor/ | ||||
| plugins-storage/ | ||||
| plugins-local/ | ||||
| traefik_changelog.md | ||||
| integration/tailscale.secret | ||||
|   | ||||
							
								
								
									
										219
									
								
								.golangci.toml
									
									
									
									
									
								
							
							
						
						
									
										219
									
								
								.golangci.toml
									
									
									
									
									
								
							| @@ -1,219 +0,0 @@ | ||||
| [run] | ||||
|   timeout = "10m" | ||||
|   skip-files = [] | ||||
|   skip-dirs = [ | ||||
|     "pkg/provider/kubernetes/crd/generated/", | ||||
|   ] | ||||
|  | ||||
| [linters-settings] | ||||
|  | ||||
|   [linters-settings.govet] | ||||
|     check-shadowing = false | ||||
|  | ||||
|   [linters-settings.golint] | ||||
|     min-confidence = 0.0 | ||||
|  | ||||
|   [linters-settings.gocyclo] | ||||
|     min-complexity = 14.0 | ||||
|  | ||||
|   [linters-settings.goconst] | ||||
|     min-len = 3.0 | ||||
|     min-occurrences = 4.0 | ||||
|  | ||||
|   [linters-settings.misspell] | ||||
|     locale = "US" | ||||
|  | ||||
|   [linters-settings.funlen] | ||||
|     lines = 230 # default 60 | ||||
|     statements = 120 # default 40 | ||||
|  | ||||
|   [linters-settings.forbidigo] | ||||
|     forbid = [ | ||||
|       '^print(ln)?$', | ||||
|       '^spew\.Print(f|ln)?$', | ||||
|       '^spew\.Dump$', | ||||
|     ] | ||||
|  | ||||
|   [linters-settings.depguard] | ||||
|     list-type = "blacklist" | ||||
|     include-go-root = false | ||||
|     packages = ["github.com/pkg/errors"] | ||||
|  | ||||
|   [linters-settings.godox] | ||||
|     keywords = ["FIXME"] | ||||
|  | ||||
|   [linters-settings.importas] | ||||
|     corev1 = "k8s.io/api/core/v1" | ||||
|     networkingv1beta1 = "k8s.io/api/networking/v1beta1" | ||||
|     extensionsv1beta1 = "k8s.io/api/extensions/v1beta1" | ||||
|     metav1 = "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
|     kubeerror = "k8s.io/apimachinery/pkg/api/errors" | ||||
|     composeapi = "github.com/docker/compose/v2/pkg/api" | ||||
|  | ||||
|   [linters-settings.revive] | ||||
|     [[linters-settings.revive.rules]] | ||||
|       name = "struct-tag" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "blank-imports" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "context-as-argument" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "context-keys-type" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "dot-imports" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "error-return" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "error-strings" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "error-naming" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "exported" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "if-return" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "increment-decrement" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "var-naming" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "var-declaration" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "package-comments" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "range" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "receiver-naming" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "time-naming" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "unexported-return" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "indent-error-flow" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "errorf" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "empty-block" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "superfluous-else" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "unused-parameter" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "unreachable-code" | ||||
|     [[linters-settings.rules]] | ||||
|       name = "redefines-builtin-id" | ||||
|  | ||||
|   [linters-settings.gomoddirectives] | ||||
|     replace-allow-list = [ | ||||
|       "github.com/abbot/go-http-auth", | ||||
|       "github.com/go-check/check", | ||||
|       "github.com/gorilla/mux", | ||||
|       "github.com/mailgun/minheap", | ||||
|       "github.com/mailgun/multibuf", | ||||
|       "github.com/jaguilar/vt100", | ||||
|     ] | ||||
|  | ||||
| [linters] | ||||
|   enable-all = true | ||||
|   disable = [ | ||||
|     "scopelint", # Deprecated | ||||
|     "interfacer", # Deprecated | ||||
|     "maligned", # Deprecated | ||||
|     "golint", # Deprecated | ||||
|     "execinquery", # Not relevant (SQL) | ||||
|     "sqlclosecheck", # Not relevant (SQL) | ||||
|     "rowserrcheck", # Not relevant (SQL) | ||||
|     "lll", # Not relevant | ||||
|     "gocyclo", # FIXME must be fixed | ||||
|     "cyclop", # Duplicate of gocyclo | ||||
|     "gocognit", # Too strict | ||||
|     "nestif", # Too many false-positive. | ||||
|     "prealloc", # Too many false-positive. | ||||
|     "makezero", # Not relevant | ||||
|     "ifshort", # Not relevant | ||||
|     "dupl", # Too strict | ||||
|     "gosec", # Too strict | ||||
|     "gochecknoinits", | ||||
|     "gochecknoglobals", | ||||
|     "wsl", # Too strict | ||||
|     "nlreturn", # Not relevant | ||||
|     "gomnd", # Too strict | ||||
|     "stylecheck", # skip because report issues related to some generated files. | ||||
|     "testpackage", # Too strict | ||||
|     "tparallel", # Not relevant | ||||
|     "paralleltest", # Not relevant | ||||
|     "exhaustive", # Not relevant | ||||
|     "exhaustivestruct", # Not relevant | ||||
|     "exhaustruct", # duplicate of exhaustivestruct | ||||
|     "goerr113", # Too strict | ||||
|     "wrapcheck", # Too strict | ||||
|     "noctx", # Too strict | ||||
|     "bodyclose", # Too many false-positive and panics. | ||||
|     "unparam", # Too strict | ||||
|     "godox", # Too strict | ||||
|     "forcetypeassert", # Too strict | ||||
|     "tagliatelle", # Not compatible with current tags. | ||||
|     "varnamelen", # not relevant | ||||
|     "nilnil", # not relevant | ||||
|     "ireturn", # not relevant | ||||
|     "contextcheck", # too many false-positive | ||||
|     "containedctx", # too many false-positive | ||||
|     "maintidx", # kind of duplicate of gocyclo | ||||
|     "nonamedreturns", # not relevant | ||||
|   ] | ||||
|  | ||||
| [issues] | ||||
|   exclude-use-default = false | ||||
|   max-per-linter = 0 | ||||
|   max-same-issues = 0 | ||||
|   exclude = [ | ||||
|     "Error return value of .((os\\.)?std(out|err)\\..*|.*Close|.*Flush|os\\.Remove(All)?|.*printf?|os\\.(Un)?Setenv). is not checked", | ||||
|     "should have a package comment, unless it's in another file for this package", | ||||
|     "SA1019: http.CloseNotifier has been deprecated",  # FIXME must be fixed | ||||
|     "SA1019: cfg.SSLRedirect is deprecated", | ||||
|     "SA1019: cfg.SSLTemporaryRedirect is deprecated", | ||||
|     "SA1019: cfg.SSLHost is deprecated", | ||||
|     "SA1019: cfg.SSLForceHost is deprecated", | ||||
|     "SA1019: cfg.FeaturePolicy is deprecated", | ||||
|   ] | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "(.+)_test.go" | ||||
|     linters = ["goconst", "funlen", "godot"] | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "integration/.+_test.go" | ||||
|     text = "Error return value of `cmd\\.Process\\.Kill` is not checked" | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "integration/(consul_catalog_test|constraint_test).go" | ||||
|     text = "Error return value of `(s.deregisterService|s.deregisterAgentService)` is not checked" | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "integration/grpc_test.go" | ||||
|     text = "Error return value of `closer` is not checked" | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "pkg/h2c/h2c.go" | ||||
|     text = "Error return value of `rw.Write` is not checked" | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "pkg/provider/docker/builder_test.go" | ||||
|     text = "(U1000: func )?`(.+)` is unused" | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "pkg/provider/kubernetes/builder_(endpoint|service)_test.go" | ||||
|     text = "(U1000: func )?`(.+)` is unused" | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "pkg/server/service/bufferpool.go" | ||||
|     text = "SA6002: argument should be pointer-like to avoid allocations" | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "cmd/configuration.go" | ||||
|     text = "string `traefik` has (\\d) occurrences, make it a constant" | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "pkg/server/middleware/middlewares.go" | ||||
|     text = "Function 'buildConstructor' has too many statements" | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "pkg/tracing/haystack/logger.go" | ||||
|     linters = ["goprintffuncname"] | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "pkg/tracing/tracing.go" | ||||
|     text = "printf-like formatting function 'SetErrorWithEvent' should be named 'SetErrorWithEventf'" | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "pkg/log/deprecated.go" | ||||
|     linters = ["godot"] | ||||
|  [[issues.exclude-rules]] | ||||
|     path = "(.+)\\.go" | ||||
|     text = "struct-tag: unknown option 'inline' in JSON tag" | ||||
							
								
								
									
										266
									
								
								.golangci.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										266
									
								
								.golangci.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,266 @@ | ||||
| run: | ||||
|   timeout: 10m | ||||
|   skip-files: [] | ||||
|   skip-dirs: | ||||
|     - pkg/provider/kubernetes/crd/generated/ | ||||
|  | ||||
| linters-settings: | ||||
|   govet: | ||||
|     enable-all: true | ||||
|     disable: | ||||
|       - shadow | ||||
|       - fieldalignment | ||||
|   gocyclo: | ||||
|     min-complexity: 14 | ||||
|   goconst: | ||||
|     min-len: 3 | ||||
|     min-occurrences: 4 | ||||
|   misspell: | ||||
|     locale: US | ||||
|   funlen: | ||||
|     lines: -1 | ||||
|     statements: 120 | ||||
|   forbidigo: | ||||
|     forbid: | ||||
|       - ^print(ln)?$ | ||||
|       - ^spew\.Print(f|ln)?$ | ||||
|       - ^spew\.Dump$ | ||||
|   depguard: | ||||
|     rules: | ||||
|       main: | ||||
|         deny: | ||||
|           - pkg: "github.com/instana/testify" | ||||
|             desc: not allowed | ||||
|           - pkg: "github.com/pkg/errors" | ||||
|             desc: Should be replaced by standard lib errors package | ||||
|           - pkg: "k8s.io/api/networking/v1beta1" | ||||
|             desc: This API is deprecated | ||||
|           - pkg: "k8s.io/api/extensions/v1beta1" | ||||
|             desc: This API is deprecated | ||||
|   godox: | ||||
|     keywords: | ||||
|       - FIXME | ||||
|   importas: | ||||
|     no-unaliased: true | ||||
|     alias: | ||||
|       - alias: composeapi | ||||
|         pkg: github.com/docker/compose/v2/pkg/api | ||||
|  | ||||
|       # Standard Kubernetes rewrites: | ||||
|       - alias: corev1 | ||||
|         pkg: "k8s.io/api/core/v1" | ||||
|       - alias: netv1 | ||||
|         pkg: "k8s.io/api/networking/v1" | ||||
|       - alias: admv1 | ||||
|         pkg: "k8s.io/api/admission/v1" | ||||
|       - alias: admv1beta1 | ||||
|         pkg: "k8s.io/api/admission/v1beta1" | ||||
|       - alias: metav1 | ||||
|         pkg: "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
|       - alias: ktypes | ||||
|         pkg: "k8s.io/apimachinery/pkg/types" | ||||
|       - alias: kerror | ||||
|         pkg: "k8s.io/apimachinery/pkg/api/errors" | ||||
|       - alias: kclientset | ||||
|         pkg: "k8s.io/client-go/kubernetes" | ||||
|       - alias: kinformers | ||||
|         pkg: "k8s.io/client-go/informers" | ||||
|       - alias: ktesting | ||||
|         pkg: "k8s.io/client-go/testing" | ||||
|       - alias: kschema | ||||
|         pkg: "k8s.io/apimachinery/pkg/runtime/schema" | ||||
|       - alias: kscheme | ||||
|         pkg: "k8s.io/client-go/kubernetes/scheme" | ||||
|       - alias: kversion | ||||
|         pkg: "k8s.io/apimachinery/pkg/version" | ||||
|       - alias: kubefake | ||||
|         pkg: "k8s.io/client-go/kubernetes/fake" | ||||
|       - alias: discoveryfake | ||||
|         pkg: "k8s.io/client-go/discovery/fake" | ||||
|  | ||||
|       # Kubernetes Gateway rewrites: | ||||
|       - alias: gateclientset | ||||
|         pkg: "sigs.k8s.io/gateway-api/pkg/client/clientset/gateway/versioned" | ||||
|       - alias: gateinformers | ||||
|         pkg: "sigs.k8s.io/gateway-api/pkg/client/informers/gateway/externalversions" | ||||
|       - alias: gatev1alpha2 | ||||
|         pkg: "sigs.k8s.io/gateway-api/apis/v1alpha2" | ||||
|  | ||||
|       # Traefik Kubernetes rewrites: | ||||
|       - alias: containousv1alpha1 | ||||
|         pkg: "github.com/traefik/traefik/v3/pkg/provider/kubernetes/crd/traefikcontainous/v1alpha1" | ||||
|       - alias: traefikv1alpha1 | ||||
|         pkg: "github.com/traefik/traefik/v3/pkg/provider/kubernetes/crd/traefikio/v1alpha1" | ||||
|       - alias: traefikclientset | ||||
|         pkg: "github.com/traefik/traefik/v3/pkg/provider/kubernetes/crd/generated/clientset/versioned" | ||||
|       - alias: traefikinformers | ||||
|         pkg: "github.com/traefik/traefik/v3/pkg/provider/kubernetes/crd/generated/informers/externalversions" | ||||
|       - alias: traefikscheme | ||||
|         pkg: "github.com/traefik/traefik/v3/pkg/provider/kubernetes/crd/generated/clientset/versioned/scheme" | ||||
|       - alias: traefikcrdfake | ||||
|         pkg: "github.com/traefik/traefik/v3/pkg/provider/kubernetes/crd/generated/clientset/versioned/fake" | ||||
|   tagalign: | ||||
|     align: false | ||||
|     sort: true | ||||
|     order: | ||||
|       - description | ||||
|       - json | ||||
|       - toml | ||||
|       - yaml | ||||
|       - yml | ||||
|       - label | ||||
|       - label-slice-as-struct | ||||
|       - file | ||||
|       - kv | ||||
|       - export | ||||
|   revive: | ||||
|     rules: | ||||
|       - name: struct-tag | ||||
|       - name: blank-imports | ||||
|       - name: context-as-argument | ||||
|       - name: context-keys-type | ||||
|       - name: dot-imports | ||||
|       - name: error-return | ||||
|       - name: error-strings | ||||
|       - name: error-naming | ||||
|       - name: exported | ||||
|         disabled: true | ||||
|       - name: if-return | ||||
|       - name: increment-decrement | ||||
|       - name: var-naming | ||||
|       - name: var-declaration | ||||
|       - name: package-comments | ||||
|         disabled: true | ||||
|       - name: range | ||||
|       - name: receiver-naming | ||||
|       - name: time-naming | ||||
|       - name: unexported-return | ||||
|       - name: indent-error-flow | ||||
|       - name: errorf | ||||
|       - name: empty-block | ||||
|       - name: superfluous-else | ||||
|       - name: unused-parameter | ||||
|         disabled: true | ||||
|       - name: unreachable-code | ||||
|       - name: redefines-builtin-id | ||||
|   gomoddirectives: | ||||
|     replace-allow-list: | ||||
|       - github.com/abbot/go-http-auth | ||||
|       - github.com/go-check/check | ||||
|       - github.com/gorilla/mux | ||||
|       - github.com/mailgun/minheap | ||||
|       - github.com/mailgun/multibuf | ||||
|       - github.com/jaguilar/vt100 | ||||
|  | ||||
| linters: | ||||
|   enable-all: true | ||||
|   disable: | ||||
|     - deadcode # deprecated | ||||
|     - exhaustivestruct # deprecated | ||||
|     - golint # deprecated | ||||
|     - ifshort # deprecated | ||||
|     - interfacer # deprecated | ||||
|     - maligned # deprecated | ||||
|     - nosnakecase # deprecated | ||||
|     - scopelint # deprecated | ||||
|     - scopelint # deprecated | ||||
|     - structcheck # deprecated | ||||
|     - varcheck # deprecated | ||||
|     - sqlclosecheck # not relevant (SQL) | ||||
|     - rowserrcheck # not relevant (SQL) | ||||
|     - execinquery # not relevant (SQL) | ||||
|     - cyclop # duplicate of gocyclo | ||||
|     - lll # Not relevant | ||||
|     - gocyclo # FIXME must be fixed | ||||
|     - gocognit # Too strict | ||||
|     - nestif # Too many false-positive. | ||||
|     - prealloc # Too many false-positive. | ||||
|     - makezero # Not relevant | ||||
|     - dupl # Too strict | ||||
|     - gosec # Too strict | ||||
|     - gochecknoinits | ||||
|     - gochecknoglobals | ||||
|     - wsl # Too strict | ||||
|     - nlreturn # Not relevant | ||||
|     - gomnd # Too strict | ||||
|     - stylecheck # skip because report issues related to some generated files. | ||||
|     - testpackage # Too strict | ||||
|     - tparallel # Not relevant | ||||
|     - paralleltest # Not relevant | ||||
|     - exhaustive # Not relevant | ||||
|     - exhaustruct # Not relevant | ||||
|     - goerr113 # Too strict | ||||
|     - wrapcheck # Too strict | ||||
|     - noctx # Too strict | ||||
|     - bodyclose # too many false-positive | ||||
|     - forcetypeassert # Too strict | ||||
|     - tagliatelle # Too strict | ||||
|     - varnamelen # Not relevant | ||||
|     - nilnil # Not relevant | ||||
|     - ireturn # Not relevant | ||||
|     - contextcheck # too many false-positive | ||||
|     - containedctx # too many false-positive | ||||
|     - maintidx # kind of duplicate of gocyclo | ||||
|     - nonamedreturns # Too strict | ||||
|     - gosmopolitan  # not relevant | ||||
|  | ||||
| issues: | ||||
|   exclude-use-default: false | ||||
|   max-per-linter: 0 | ||||
|   max-same-issues: 0 | ||||
|   exclude: | ||||
|     - 'Error return value of .((os\.)?std(out|err)\..*|.*Close|.*Flush|os\.Remove(All)?|.*printf?|os\.(Un)?Setenv). is not checked' | ||||
|     - "should have a package comment, unless it's in another file for this package" | ||||
|   exclude-rules: | ||||
|     - path: '(.+)_test.go' | ||||
|       linters: | ||||
|         - goconst | ||||
|         - funlen | ||||
|         - godot | ||||
|     - path: '(.+)_test.go' | ||||
|       text: ' always receives ' | ||||
|       linters: | ||||
|         - unparam | ||||
|     - path: '(.+)\.go' | ||||
|       text: 'struct-tag: unknown option ''inline'' in JSON tag' | ||||
|       linters: | ||||
|         - revive | ||||
|     - path: pkg/server/service/bufferpool.go | ||||
|       text: 'SA6002: argument should be pointer-like to avoid allocations' | ||||
|     - path: pkg/server/middleware/middlewares.go | ||||
|       text: "Function 'buildConstructor' has too many statements" | ||||
|       linters: | ||||
|         - funlen | ||||
|     - path: pkg/logs/haystack.go | ||||
|       linters: | ||||
|         - goprintffuncname | ||||
|     - path: pkg/tracing/tracing.go | ||||
|       text: "printf-like formatting function 'SetErrorWithEvent' should be named 'SetErrorWithEventf'" | ||||
|       linters: | ||||
|         - goprintffuncname | ||||
|     - path: pkg/tls/tlsmanager_test.go | ||||
|       text: 'SA1019: config.ClientCAs.Subjects has been deprecated since Go 1.18' | ||||
|     - path: pkg/types/tls_test.go | ||||
|       text: 'SA1019: tlsConfig.RootCAs.Subjects has been deprecated since Go 1.18' | ||||
|     - path: pkg/provider/kubernetes/(crd|gateway)/client.go | ||||
|       linters: | ||||
|         - interfacebloat | ||||
|     - path: pkg/metrics/metrics.go | ||||
|       linters: | ||||
|         - interfacebloat | ||||
|     - path: integration/healthcheck_test.go | ||||
|       text: 'Duplicate words \(wsp2,\) found' | ||||
|       linters: | ||||
|         - dupword | ||||
|     - path: pkg/types/domain_test.go | ||||
|       text: 'Duplicate words \(sub\) found' | ||||
|       linters: | ||||
|         - dupword | ||||
|     - path: pkg/provider/kubernetes/crd/kubernetes.go | ||||
|       text: "Function 'loadConfigurationFromCRD' has too many statements" | ||||
|       linters: | ||||
|         - funlen | ||||
|     - path: pkg/provider/kubernetes/gateway/client_mock_test.go | ||||
|       text: 'unusedwrite: unused write to field' | ||||
|       linters: | ||||
|         - govet | ||||
| @@ -11,7 +11,7 @@ builds: | ||||
|     env: | ||||
|       - CGO_ENABLED=0 | ||||
|     ldflags: | ||||
|       - -s -w -X github.com/traefik/traefik/v2/pkg/version.Version={{.Version}} -X github.com/traefik/traefik/v2/pkg/version.Codename={{.Env.CODENAME}} -X github.com/traefik/traefik/v2/pkg/version.BuildDate={{.Date}} | ||||
|       - -s -w -X github.com/traefik/traefik/v3/pkg/version.Version={{.Version}} -X github.com/traefik/traefik/v3/pkg/version.Codename={{.Env.CODENAME}} -X github.com/traefik/traefik/v3/pkg/version.BuildDate={{.Date}} | ||||
|     flags: | ||||
|       - -trimpath | ||||
|     goos: | ||||
| @@ -22,24 +22,27 @@ builds: | ||||
|       - openbsd | ||||
|     goarch: | ||||
|       - amd64 | ||||
|       - 386 | ||||
|       - '386' | ||||
|       - arm | ||||
|       - arm64 | ||||
|       - ppc64le | ||||
|       - s390x | ||||
|     goarm: | ||||
|       - 7 | ||||
|       - 6 | ||||
|       - 5 | ||||
|       - '7' | ||||
|       - '6' | ||||
|     ignore: | ||||
|       - goos: darwin | ||||
|         goarch: 386 | ||||
|         goarch: '386' | ||||
|       - goos: openbsd | ||||
|         goarch: arm | ||||
|       - goos: openbsd | ||||
|         goarch: arm64 | ||||
|       - goos: freebsd | ||||
|         goarch: arm | ||||
|       - goos: freebsd | ||||
|         goarch: arm64 | ||||
|       - goos: windows | ||||
|         goarch: arm | ||||
|  | ||||
| changelog: | ||||
|   skip: true | ||||
|   | ||||
| @@ -3,7 +3,7 @@ name: Traefik | ||||
| agent: | ||||
|   machine: | ||||
|     type: e1-standard-4 | ||||
|     os_image: ubuntu1804 | ||||
|     os_image: ubuntu2004 | ||||
|  | ||||
| fail_fast: | ||||
|   stop: | ||||
| @@ -19,13 +19,13 @@ global_job_config: | ||||
|   prologue: | ||||
|     commands: | ||||
|       - curl -sSfL https://raw.githubusercontent.com/ldez/semgo/master/godownloader.sh | sudo sh -s -- -b "/usr/local/bin" | ||||
|       - sudo semgo go1.17 | ||||
|       - sudo semgo go1.20 | ||||
|       - export "GOPATH=$(go env GOPATH)" | ||||
|       - export "SEMAPHORE_GIT_DIR=${GOPATH}/src/github.com/traefik/${SEMAPHORE_PROJECT_NAME}" | ||||
|       - export "PATH=${GOPATH}/bin:${PATH}" | ||||
|       - mkdir -vp "${SEMAPHORE_GIT_DIR}" "${GOPATH}/bin" | ||||
|       - export GOPROXY=https://proxy.golang.org,direct | ||||
|       - curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b "${GOPATH}/bin" v1.46.2 | ||||
|       - curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b "${GOPATH}/bin" v1.52.2 | ||||
|       - curl -sSfL https://gist.githubusercontent.com/traefiker/6d7ac019c11d011e4f131bb2cca8900e/raw/goreleaser.sh | bash -s -- -b "${GOPATH}/bin" | ||||
|       - checkout | ||||
|       - cache restore traefik-$(checksum go.sum) | ||||
| @@ -57,14 +57,14 @@ blocks: | ||||
|       agent: | ||||
|         machine: | ||||
|           type: e1-standard-8 | ||||
|           os_image: ubuntu1804 | ||||
|           os_image: ubuntu2004 | ||||
|       secrets: | ||||
|         - name: traefik | ||||
|       env_vars: | ||||
|         - name: GH_VERSION | ||||
|           value: 1.12.1 | ||||
|         - name: CODENAME | ||||
|           value: "rocamadour" | ||||
|           value: "beaufort" | ||||
|         - name: IN_DOCKER | ||||
|           value: "" | ||||
|       prologue: | ||||
| @@ -73,7 +73,7 @@ blocks: | ||||
|           - curl -sSL -o /tmp/gh_${GH_VERSION}_linux_amd64.tar.gz https://github.com/cli/cli/releases/download/v${GH_VERSION}/gh_${GH_VERSION}_linux_amd64.tar.gz | ||||
|           - tar -zxvf /tmp/gh_${GH_VERSION}_linux_amd64.tar.gz -C /tmp | ||||
|           - sudo mv /tmp/gh_${GH_VERSION}_linux_amd64/bin/gh /usr/local/bin/gh | ||||
|           - sudo rm -rf ~/.phpbrew ~/.kerl ~/.sbt ~/.nvm ~/.npm ~/.kiex /usr/lib/jvm /opt/az /opt/firefox # Remove unnecessary data. | ||||
|           - sudo rm -rf ~/.phpbrew ~/.kerl ~/.sbt ~/.nvm ~/.npm ~/.kiex /usr/lib/jvm /opt/az /opt/firefox /usr/lib/google-cloud-sdk ~/.rbenv ~/.pip_download_cache # Remove unnecessary data. | ||||
|           - sudo service docker stop && sudo umount /var/lib/docker && sudo service docker start # Unmounts the docker disk and the whole system disk is usable. | ||||
|       jobs: | ||||
|         - name: Release | ||||
|   | ||||
							
								
								
									
										745
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										745
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,3 +1,694 @@ | ||||
| ## [v3.0.0-beta3](https://github.com/traefik/traefik/tree/v3.0.0-beta3) (2023-06-21) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v3.0.0-beta2...v3.0.0-beta3) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[docker,docker/swarm]** Split Docker provider ([#9652](https://github.com/traefik/traefik/pull/9652) by [ldez](https://github.com/ldez)) | ||||
| - **[k8s,hub]** Remove deprecated code ([#9804](https://github.com/traefik/traefik/pull/9804) by [ldez](https://github.com/ldez)) | ||||
| - **[k8s,k8s/gatewayapi]** Support HostSNIRegexp in GatewayAPI TLS routes ([#9486](https://github.com/traefik/traefik/pull/9486) by [ddtmachado](https://github.com/ddtmachado)) | ||||
| - **[k8s/gatewayapi]** Add support for HTTPRequestRedirectFilter in k8s Gateway API ([#9408](https://github.com/traefik/traefik/pull/9408) by [romantomjak](https://github.com/romantomjak)) | ||||
| - **[k8s/ingress,k8s]** Remove support of the networking.k8s.io/v1beta1 APIVersion ([#9949](https://github.com/traefik/traefik/pull/9949) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[k8s/ingress,k8s]** Add option to the Ingress provider to disable IngressClass lookup ([#9281](https://github.com/traefik/traefik/pull/9281) by [jandillenkofer](https://github.com/jandillenkofer)) | ||||
| - **[marathon]** Remove Marathon provider ([#9614](https://github.com/traefik/traefik/pull/9614) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[metrics]** Remove InfluxDB v1 metrics middleware ([#9612](https://github.com/traefik/traefik/pull/9612) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[rancher]** Remove Rancher v1 provider ([#9613](https://github.com/traefik/traefik/pull/9613) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[rules]** Remove containous/mux from HTTP muxer ([#9558](https://github.com/traefik/traefik/pull/9558) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[tls,tcp,service]** Add TCP Servers Transports support ([#9465](https://github.com/traefik/traefik/pull/9465) by [sdelicata](https://github.com/sdelicata)) | ||||
| - **[webui]** Added router priority to webui's list and detail page ([#9004](https://github.com/traefik/traefik/pull/9004) by [bendre90](https://github.com/bendre90)) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[metrics]** Fix OpenTelemetry metrics ([#9962](https://github.com/traefik/traefik/pull/9962) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[metrics]** Remove config reload failure metrics ([#9660](https://github.com/traefik/traefik/pull/9660) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[metrics]** Fix open connections metric ([#9656](https://github.com/traefik/traefik/pull/9656) by [mpl](https://github.com/mpl)) | ||||
| - **[metrics]** Fix OpenTelemetry service name ([#9619](https://github.com/traefik/traefik/pull/9619) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[tcp]** Don't log EOF or timeout errors while peeking first bytes in Postgres StartTLS hook ([#9663](https://github.com/traefik/traefik/pull/9663) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[webui]** Detect dashboard assets content types ([#9622](https://github.com/traefik/traefik/pull/9622) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[webui]** fix: detect dashboard content types ([#9594](https://github.com/traefik/traefik/pull/9594) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[k8s]** Improve Kubernetes support documentation ([#9974](https://github.com/traefik/traefik/pull/9974) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Adjust quick start ([#9790](https://github.com/traefik/traefik/pull/9790) by [svx](https://github.com/svx)) | ||||
| - Mention PathPrefix matcher changes in V3 Migration Guide ([#9727](https://github.com/traefik/traefik/pull/9727) by [aofei](https://github.com/aofei)) | ||||
| - Fix yaml indentation in the HTTP3 example ([#9724](https://github.com/traefik/traefik/pull/9724) by [benwaffle](https://github.com/benwaffle)) | ||||
| - Add OpenTelemetry in observability overview ([#9654](https://github.com/traefik/traefik/pull/9654) by [tomMoulard](https://github.com/tomMoulard)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge branch v2.10 into v3.0 ([#9977](https://github.com/traefik/traefik/pull/9977) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.10 into v3.0 ([#9931](https://github.com/traefik/traefik/pull/9931) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.10 into v3.0 ([#9896](https://github.com/traefik/traefik/pull/9896) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.10 into v3.0 ([#9867](https://github.com/traefik/traefik/pull/9867) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.10 into v3.0 ([#9850](https://github.com/traefik/traefik/pull/9850) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.10 into v3.0 ([#9845](https://github.com/traefik/traefik/pull/9845) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.10 into v3.0 ([#9803](https://github.com/traefik/traefik/pull/9803) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.10 into v3.0 ([#9793](https://github.com/traefik/traefik/pull/9793) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.9 into v3.0 ([#9722](https://github.com/traefik/traefik/pull/9722) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge branch v2.9 into v3.0 ([#9650](https://github.com/traefik/traefik/pull/9650) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge branch v2.9 into v3.0 ([#9632](https://github.com/traefik/traefik/pull/9632) by [kevinpollet](https://github.com/kevinpollet)) | ||||
|  | ||||
| ## [v2.10.3](https://github.com/traefik/traefik/tree/v2.10.3) (2023-06-17) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.10.2...v2.10.3) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[acme]** Update go-acme/lego to v4.12.2 ([#9935](https://github.com/traefik/traefik/pull/9971) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| ## [v2.10.2](https://github.com/traefik/traefik/tree/v2.10.2) (2023-06-17) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.10.1...v2.10.2) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[acme]** Update go-acme/lego to v4.12.1 ([#9935](https://github.com/traefik/traefik/pull/9935) by [ldez](https://github.com/ldez)) | ||||
| - **[acme]** Update go-acme/lego to v4.12.0 ([#9918](https://github.com/traefik/traefik/pull/9918) by [ldez](https://github.com/ldez)) | ||||
| - **[acme]** Update go-acme/lego to v4.11.0 ([#9883](https://github.com/traefik/traefik/pull/9883) by [ldez](https://github.com/ldez)) | ||||
| - **[acme]** Do not check for wildcard domains for non DNS challenge ([#9881](https://github.com/traefik/traefik/pull/9881) by [erkexzcx](https://github.com/erkexzcx)) | ||||
| - **[k8s/crd]** Fix multiple subsets endpoint ([#9914](https://github.com/traefik/traefik/pull/9914) by [joaosilva15](https://github.com/joaosilva15)) | ||||
| - **[k8s/ingress,k8s/crd,k8s,hub]** Clean code related to Hub ([#9894](https://github.com/traefik/traefik/pull/9894) by [ldez](https://github.com/ldez)) | ||||
| - **[metrics]** Enable Prometheus provider cleanup when only the router's metrics level is activated ([#9887](https://github.com/traefik/traefik/pull/9887) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[middleware]** Encode query semicolons ([#9943](https://github.com/traefik/traefik/pull/9943) by [LandryBe](https://github.com/LandryBe)) | ||||
| - **[middleware]** Missing trailer with custom errors middleware ([#9942](https://github.com/traefik/traefik/pull/9942) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[middleware]** Support informational headers in middlewares redefining the response writer. ([#9938](https://github.com/traefik/traefik/pull/9938) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[plugins]** Improve error messages related to plugins ([#9924](https://github.com/traefik/traefik/pull/9924) by [ldez](https://github.com/ldez)) | ||||
| - **[tracing]** Update DataDog tracing dependency to v1.50.1 ([#9953](https://github.com/traefik/traefik/pull/9953) by [der-eismann](https://github.com/der-eismann)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[accesslogs]** Fix over-indented yaml configuration of access logs ([#9930](https://github.com/traefik/traefik/pull/9930) by [ufUNnxagpM](https://github.com/ufUNnxagpM)) | ||||
| - **[tls]** Add FAQ documentation about TLS certificates ([#9868](https://github.com/traefik/traefik/pull/9868) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Fix typo ([#9966](https://github.com/traefik/traefik/pull/9966) by [green1052](https://github.com/green1052)) | ||||
| - Add business callouts ([#9940](https://github.com/traefik/traefik/pull/9940) by [tomatokoolaid](https://github.com/tomatokoolaid)) | ||||
| - Add logo for GitHub dark mode ([#9890](https://github.com/traefik/traefik/pull/9890) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| ## [v2.10.1](https://github.com/traefik/traefik/tree/v2.10.1) (2023-04-27) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.10.0...v2.10.1) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[middleware,oxy]** Update vulcand/oxy to be5cf38 ([#9874](https://github.com/traefik/traefik/pull/9874) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| **Documentation:** | ||||
| - Fix v2.10 migration guide ([#9863](https://github.com/traefik/traefik/pull/9863) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| ## [v2.10.0](https://github.com/traefik/traefik/tree/v2.10.0) (2023-04-24) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.0-rc1...v2.10.0) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[docker]** Expose ContainerName in Docker provider ([#9770](https://github.com/traefik/traefik/pull/9770) by [quinot](https://github.com/quinot)) | ||||
| - **[hub]** Remove hub configuration out of experimental ([#9792](https://github.com/traefik/traefik/pull/9792) by [mpl](https://github.com/mpl)) | ||||
| - **[k8s/crd]** Introduce traefik.io API Group CRDs ([#9765](https://github.com/traefik/traefik/pull/9765) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[k8s/ingress,k8s/crd,k8s]** Native Kubernetes service load-balancing ([#9740](https://github.com/traefik/traefik/pull/9740) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[middleware,metrics]** Add prometheus metric requests_total with headers ([#9783](https://github.com/traefik/traefik/pull/9783) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[nomad]** Support multiple namespaces in the Nomad Provider ([#9794](https://github.com/traefik/traefik/pull/9794) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[tracing]** Add support to send DataDog traces via Unix Socket ([#9714](https://github.com/traefik/traefik/pull/9714) by [der-eismann](https://github.com/der-eismann)) | ||||
| - **[webui]** Modify the Hub Button ([#9851](https://github.com/traefik/traefik/pull/9851) by [mdeliatf](https://github.com/mdeliatf)) | ||||
| - **[webui]** Display period setting of the RateLimit middleware in the webui ([#9822](https://github.com/traefik/traefik/pull/9822) by [smatyas](https://github.com/smatyas)) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[docker]** Only warn about missing docker network when network_mode is not host or container ([#9799](https://github.com/traefik/traefik/pull/9799) by [sentriz](https://github.com/sentriz)) | ||||
| - **[k8s/ingress,k8s]** Bump k8s.io/client-go from v0.22.1 to v0.26.3 ([#9808](https://github.com/traefik/traefik/pull/9808) by [ldez](https://github.com/ldez)) | ||||
| - **[plugins]** Improve DeepCopy of PluginConf ([#9846](https://github.com/traefik/traefik/pull/9846) by [ldez](https://github.com/ldez)) | ||||
| - **[plugins]** Update Yaegi to v0.15.1 ([#9815](https://github.com/traefik/traefik/pull/9815) by [ldez](https://github.com/ldez)) | ||||
| - **[server]** Update vulcand/oxy to 03de175b3822 ([#9849](https://github.com/traefik/traefik/pull/9849) by [longit644](https://github.com/longit644)) | ||||
|  | ||||
| **Documentation:** | ||||
| - Prepare release v2.10.0-rc1 ([#9802](https://github.com/traefik/traefik/pull/9802) by [ldez](https://github.com/ldez)) | ||||
| - Fix order of log levels ([#9791](https://github.com/traefik/traefik/pull/9791) by [svx](https://github.com/svx)) | ||||
| - **[docker]** Update wording - add link descriptions ([#9816](https://github.com/traefik/traefik/pull/9816) by [svx](https://github.com/svx)) | ||||
| - **[middleware]** Add accessControlAllowHeaders example ([#9810](https://github.com/traefik/traefik/pull/9810) by [yingshaoxo](https://github.com/yingshaoxo)) | ||||
| - **[tls]** More details on Kubernetes options for mTLS ([#9835](https://github.com/traefik/traefik/pull/9835) by [mloiseleur](https://github.com/mloiseleur)) | ||||
| - Prepare release v2.10.0-rc2 ([#9830](https://github.com/traefik/traefik/pull/9830) by [mpl](https://github.com/mpl)) | ||||
| - Update Call To Actions ([#9824](https://github.com/traefik/traefik/pull/9824) by [svx](https://github.com/svx)) | ||||
| - Improve concepts page ([#9813](https://github.com/traefik/traefik/pull/9813) by [svx](https://github.com/svx)) | ||||
| - Update wording ([#9811](https://github.com/traefik/traefik/pull/9811) by [svx](https://github.com/svx)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge branch v2.9 into v2.10 ([#9798](https://github.com/traefik/traefik/pull/9798) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.9 into v2.10 ([#9829](https://github.com/traefik/traefik/pull/9829) by [mpl](https://github.com/mpl)) | ||||
|  | ||||
| ## [v2.10.0-rc2](https://github.com/traefik/traefik/tree/v2.10.0-rc2) (2023-04-07) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.10.0-rc1...v2.10.0-rc2) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[webui]** Display period setting of the RateLimit middleware in the webui ([#9822](https://github.com/traefik/traefik/pull/9822) by [smatyas](https://github.com/smatyas)) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[docker]** Only warn about missing docker network when network_mode is not host or container ([#9799](https://github.com/traefik/traefik/pull/9799) by [sentriz](https://github.com/sentriz)) | ||||
| - **[k8s/ingress,k8s]** chore: bump k8s.io/client-go from v0.22.1 to v0.26.3 ([#9808](https://github.com/traefik/traefik/pull/9808) by [ldez](https://github.com/ldez)) | ||||
| - **[plugins]** Update Yaegi to v0.15.1 ([#9815](https://github.com/traefik/traefik/pull/9815) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[docker]** Update wording - add link descriptions ([#9816](https://github.com/traefik/traefik/pull/9816) by [svx](https://github.com/svx)) | ||||
| - **[middleware]** Add accessControlAllowHeaders example ([#9810](https://github.com/traefik/traefik/pull/9810) by [yingshaoxo](https://github.com/yingshaoxo)) | ||||
| - Update Call To Actions ([#9824](https://github.com/traefik/traefik/pull/9824) by [svx](https://github.com/svx)) | ||||
| - Improve concepts page ([#9813](https://github.com/traefik/traefik/pull/9813) by [svx](https://github.com/svx)) | ||||
| - Update wording ([#9811](https://github.com/traefik/traefik/pull/9811) by [svx](https://github.com/svx)) | ||||
|  | ||||
| ## [v2.9.10](https://github.com/traefik/traefik/tree/v2.9.10) (2023-04-06) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.9...v2.9.10) | ||||
|  | ||||
| ## [v2.10.0-rc1](https://github.com/traefik/traefik/tree/v2.10.0-rc1) (2023-03-22) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/b3f162a8a61d89beaa9edc8adc12cc4cb3e1de0f...v2.10.0-rc1) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[docker]** Expose ContainerName in Docker provider ([#9770](https://github.com/traefik/traefik/pull/9770) by [quinot](https://github.com/quinot)) | ||||
| - **[hub]** hub: get out of experimental. ([#9792](https://github.com/traefik/traefik/pull/9792) by [mpl](https://github.com/mpl)) | ||||
| - **[k8s/crd]** Introduce traefik.io API Group CRDs ([#9765](https://github.com/traefik/traefik/pull/9765) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[k8s/ingress,k8s/crd,k8s]** Native Kubernetes service load-balancing ([#9740](https://github.com/traefik/traefik/pull/9740) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[middleware,metrics]** Add prometheus metric requests_total with headers ([#9783](https://github.com/traefik/traefik/pull/9783) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[nomad]** Support multiple namespaces in the Nomad Provider ([#9794](https://github.com/traefik/traefik/pull/9794) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[tracing]** Add support to send DataDog traces via Unix Socket ([#9714](https://github.com/traefik/traefik/pull/9714) by [der-eismann](https://github.com/der-eismann)) | ||||
|  | ||||
| **Documentation:** | ||||
| - docs: update order of log levels ([#9791](https://github.com/traefik/traefik/pull/9791) by [svx](https://github.com/svx)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.9 into v2.10 ([#9798](https://github.com/traefik/traefik/pull/9798) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| ## [v2.9.9](https://github.com/traefik/traefik/tree/v2.9.9) (2023-03-21) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.8...v2.9.9) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[acme]** Update go-acme/lego to v4.10.2 ([#9749](https://github.com/traefik/traefik/pull/9749) by [ldez](https://github.com/ldez)) | ||||
| - **[http3]** Update quic-go to v0.33.0 ([#9737](https://github.com/traefik/traefik/pull/9737) by [ldez](https://github.com/ldez)) | ||||
| - **[metrics]** Include user-defined default cert for traefik_tls_certs_not_after metric ([#9742](https://github.com/traefik/traefik/pull/9742) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[middleware]** Update vulcand/oxy to a0e9f7ff1040 ([#9750](https://github.com/traefik/traefik/pull/9750) by [ldez](https://github.com/ldez)) | ||||
| - **[nomad]** Fix default configuration settings for Nomad Provider ([#9758](https://github.com/traefik/traefik/pull/9758) by [aofei](https://github.com/aofei)) | ||||
| - **[nomad]** Fix Nomad client TLS defaults ([#9795](https://github.com/traefik/traefik/pull/9795) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[server]** Remove User-Agent header removal from ReverseProxy director func ([#9752](https://github.com/traefik/traefik/pull/9752) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[middleware]** Clarify ratelimit middleware ([#9777](https://github.com/traefik/traefik/pull/9777) by [mpl](https://github.com/mpl)) | ||||
| - **[tcp]** Correcting variable name 'server address' in TCP Router ([#9743](https://github.com/traefik/traefik/pull/9743) by [ralphg6](https://github.com/ralphg6)) | ||||
|  | ||||
| ## [v2.9.8](https://github.com/traefik/traefik/tree/v2.9.8) (2023-02-15) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.7...v2.9.8) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[server]** Update golang.org/x/net to v0.7.0 ([#9716](https://github.com/traefik/traefik/pull/9716) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| ## [v2.9.7](https://github.com/traefik/traefik/tree/v2.9.7) (2023-02-14) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.6...v2.9.7) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[acme]** Update go-acme/lego to v4.10.0 ([#9705](https://github.com/traefik/traefik/pull/9705) by [ldez](https://github.com/ldez)) | ||||
| - **[ecs]** Prevent panicking when a container has no network interfaces ([#9661](https://github.com/traefik/traefik/pull/9661) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[file]** Make file provider more resilient wrt first configuration ([#9595](https://github.com/traefik/traefik/pull/9595) by [mpl](https://github.com/mpl)) | ||||
| - **[logs]** Differentiate UDP stream and TCP connection in logs ([#9687](https://github.com/traefik/traefik/pull/9687) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[middleware]** Prevent from no rate limiting when average is zero ([#9621](https://github.com/traefik/traefik/pull/9621) by [witalisoft](https://github.com/witalisoft)) | ||||
| - **[middleware]** Prevents superfluous WriteHeader call in the error middleware ([#9620](https://github.com/traefik/traefik/pull/9620) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[middleware]** Sanitize X-Forwarded-Proto header in RedirectScheme middleware ([#9598](https://github.com/traefik/traefik/pull/9598) by [ldez](https://github.com/ldez)) | ||||
| - **[plugins]** Update paerser to v0.2.0 ([#9671](https://github.com/traefik/traefik/pull/9671) by [ldez](https://github.com/ldez)) | ||||
| - **[plugins]** Update Yaegi to v0.15.0 ([#9700](https://github.com/traefik/traefik/pull/9700) by [ldez](https://github.com/ldez)) | ||||
| - **[tls,http3]** Bump quic-go to 89769f409f ([#9685](https://github.com/traefik/traefik/pull/9685) by [mpl](https://github.com/mpl)) | ||||
| - **[tls,tcp]** Adds the support for IPv6 in the TCP HostSNI matcher ([#9692](https://github.com/traefik/traefik/pull/9692) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[acme]** Add CNAME support and gotchas ([#9698](https://github.com/traefik/traefik/pull/9698) by [mpl](https://github.com/mpl)) | ||||
| - **[acme]** Further Let's Encrypt ratelimit warnings ([#9627](https://github.com/traefik/traefik/pull/9627) by [hcooper](https://github.com/hcooper)) | ||||
| - **[k8s]** Add info admonition about routing to k8 services ([#9645](https://github.com/traefik/traefik/pull/9645) by [svx](https://github.com/svx)) | ||||
| - **[k8s]** Improve TLSStore CRD documentation ([#9579](https://github.com/traefik/traefik/pull/9579) by [mloiseleur](https://github.com/mloiseleur)) | ||||
| - **[middleware]** doc: add note about remoteaddr strategy ([#9701](https://github.com/traefik/traefik/pull/9701) by [mpl](https://github.com/mpl)) | ||||
| - Update copyright to match new standard ([#9651](https://github.com/traefik/traefik/pull/9651) by [paulocfjunior](https://github.com/paulocfjunior)) | ||||
| - Update copyright for 2023 ([#9631](https://github.com/traefik/traefik/pull/9631) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Update submitting pull requests to include language about drafts ([#9609](https://github.com/traefik/traefik/pull/9609) by [tfny](https://github.com/tfny)) | ||||
|  | ||||
| ## [v3.0.0-beta2](https://github.com/traefik/traefik/tree/v3.0.0-beta2) (2022-12-07) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v3.0.0-beta1...v3.0.0-beta2) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[http3]** Moves HTTP/3 outside the experimental section ([#9570](https://github.com/traefik/traefik/pull/9570) by [sdelicata](https://github.com/sdelicata)) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[logs]** Change traefik cmd error log to error level ([#9569](https://github.com/traefik/traefik/pull/9569) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[rules]** Rework Host and HostRegexp matchers ([#9559](https://github.com/traefik/traefik/pull/9559) by [tomMoulard](https://github.com/tomMoulard)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.9 into master ([#9586](https://github.com/traefik/traefik/pull/9586) by [tomMoulard](https://github.com/tomMoulard)) | ||||
|  | ||||
| ## [v2.9.6](https://github.com/traefik/traefik/tree/v2.9.6) (2022-12-07) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.5...v2.9.6) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[acme]** Update go-acme/lego to v4.9.1 ([#9550](https://github.com/traefik/traefik/pull/9550) by [ldez](https://github.com/ldez)) | ||||
| - **[k8s/crd]** Support of allowEmptyServices in TraefikService ([#9424](https://github.com/traefik/traefik/pull/9424) by [jeromeguiard](https://github.com/jeromeguiard)) | ||||
| - **[logs]** Remove logs of the request ([#9574](https://github.com/traefik/traefik/pull/9574) by [ldez](https://github.com/ldez)) | ||||
| - **[plugins]** Increase the timeout on plugin download ([#9529](https://github.com/traefik/traefik/pull/9529) by [ldez](https://github.com/ldez)) | ||||
| - **[server]** Update golang.org/x/net ([#9582](https://github.com/traefik/traefik/pull/9582) by [ldez](https://github.com/ldez)) | ||||
| - **[tls]** Handle broken TLS conf better ([#9572](https://github.com/traefik/traefik/pull/9572) by [mpl](https://github.com/mpl)) | ||||
| - **[tracing]** Update DataDog tracing dependency to v1.43.1 ([#9526](https://github.com/traefik/traefik/pull/9526) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[webui]** Add missing serialNumber passTLSClientCert option to middleware panel ([#9539](https://github.com/traefik/traefik/pull/9539) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[docker]** Add networking example ([#9542](https://github.com/traefik/traefik/pull/9542) by [Janik-Haag](https://github.com/Janik-Haag)) | ||||
| - **[hub]** Add information about the Hub Agent ([#9560](https://github.com/traefik/traefik/pull/9560) by [nmengin](https://github.com/nmengin)) | ||||
| - **[k8s/helm]** Update Helm installation section ([#9564](https://github.com/traefik/traefik/pull/9564) by [mloiseleur](https://github.com/mloiseleur)) | ||||
| - **[middleware]** Clarify PathPrefix matcher greediness ([#9519](https://github.com/traefik/traefik/pull/9519) by [mpl](https://github.com/mpl)) | ||||
|  | ||||
| ## [v3.0.0-beta1](https://github.com/traefik/traefik/tree/v3.0.0-beta1) (2022-12-05) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.0-rc1...v3.0.0-beta1) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[ecs]** Add option to keep only healthy ECS tasks ([#8027](https://github.com/traefik/traefik/pull/8027) by [Michampt](https://github.com/Michampt)) | ||||
| - **[healthcheck]** Support gRPC healthcheck ([#8583](https://github.com/traefik/traefik/pull/8583) by [jjacque](https://github.com/jjacque)) | ||||
| - **[healthcheck]** Add a status option to the service health check ([#9463](https://github.com/traefik/traefik/pull/9463) by [guoard](https://github.com/guoard)) | ||||
| - **[http]** Support custom headers when fetching configuration through HTTP ([#9421](https://github.com/traefik/traefik/pull/9421) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[logs,performance]** New logger for the Traefik logs ([#9515](https://github.com/traefik/traefik/pull/9515) by [ldez](https://github.com/ldez)) | ||||
| - **[logs,plugins]** Retry on plugin API calls ([#9530](https://github.com/traefik/traefik/pull/9530) by [ldez](https://github.com/ldez)) | ||||
| - **[logs,provider]** Improve provider logs ([#9562](https://github.com/traefik/traefik/pull/9562) by [ldez](https://github.com/ldez)) | ||||
| - **[logs]** Improve test logger assertions ([#9533](https://github.com/traefik/traefik/pull/9533) by [ldez](https://github.com/ldez)) | ||||
| - **[metrics]** Support gRPC and gRPC-Web protocol in metrics ([#9483](https://github.com/traefik/traefik/pull/9483) by [longit644](https://github.com/longit644)) | ||||
| - **[middleware,accesslogs]** Log TLS client subject ([#9285](https://github.com/traefik/traefik/pull/9285) by [xmessi](https://github.com/xmessi)) | ||||
| - **[middleware,metrics,tracing]** Add OpenTelemetry tracing and metrics support ([#8999](https://github.com/traefik/traefik/pull/8999) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[middleware]** Disable Content-Type auto-detection by default ([#9546](https://github.com/traefik/traefik/pull/9546) by [sdelicata](https://github.com/sdelicata)) | ||||
| - **[middleware]** Add gRPC-Web middleware ([#9451](https://github.com/traefik/traefik/pull/9451) by [juliens](https://github.com/juliens)) | ||||
| - **[middleware]** Add support for Brotli ([#9387](https://github.com/traefik/traefik/pull/9387) by [glinton](https://github.com/glinton)) | ||||
| - **[middleware]** Renaming IPWhiteList to IPAllowList  ([#9457](https://github.com/traefik/traefik/pull/9457) by [wxmbugu](https://github.com/wxmbugu)) | ||||
| - **[nomad]** Support multiple namespaces in the Nomad Provider ([#9332](https://github.com/traefik/traefik/pull/9332) by [0teh](https://github.com/0teh)) | ||||
| - **[rules]** Update routing syntax ([#9531](https://github.com/traefik/traefik/pull/9531) by [skwair](https://github.com/skwair)) | ||||
| - **[server]** Rework servers load-balancer to use the WRR ([#9431](https://github.com/traefik/traefik/pull/9431) by [juliens](https://github.com/juliens)) | ||||
| - **[server]** Allow default entrypoints definition ([#9100](https://github.com/traefik/traefik/pull/9100) by [jilleJr](https://github.com/jilleJr)) | ||||
| - **[tls,service]** Support SPIFFE mTLS between Traefik and Backend servers ([#9394](https://github.com/traefik/traefik/pull/9394) by [jlevesy](https://github.com/jlevesy)) | ||||
| - **[tls]** Add Tailscale certificate resolver ([#9237](https://github.com/traefik/traefik/pull/9237) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[tls]** Support SNI routing with Postgres STARTTLS connections ([#9377](https://github.com/traefik/traefik/pull/9377) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Remove deprecated options ([#9527](https://github.com/traefik/traefik/pull/9527) by [sdelicata](https://github.com/sdelicata)) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[logs]** Fix log level ([#9545](https://github.com/traefik/traefik/pull/9545) by [ldez](https://github.com/ldez)) | ||||
| - **[metrics]** Fix ServerUp metric ([#9534](https://github.com/traefik/traefik/pull/9534) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[tls,service]** Enforce default servers transport SPIFFE config ([#9444](https://github.com/traefik/traefik/pull/9444) by [jlevesy](https://github.com/jlevesy)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[metrics]** Update and publish official Grafana Dashboard ([#9493](https://github.com/traefik/traefik/pull/9493) by [mloiseleur](https://github.com/mloiseleur)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge branch v2.9 into master ([#9554](https://github.com/traefik/traefik/pull/9554) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.9 into master ([#9536](https://github.com/traefik/traefik/pull/9536) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.9 into master ([#9532](https://github.com/traefik/traefik/pull/9532) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.9 into master ([#9482](https://github.com/traefik/traefik/pull/9482) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge branch v2.9 into master ([#9464](https://github.com/traefik/traefik/pull/9464) by [ldez](https://github.com/ldez)) | ||||
| - Merge branch v2.9 into master ([#9449](https://github.com/traefik/traefik/pull/9449) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge branch v2.9 into master ([#9419](https://github.com/traefik/traefik/pull/9419) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge branch v2.9 into master ([#9351](https://github.com/traefik/traefik/pull/9351) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| ## [v2.9.5](https://github.com/traefik/traefik/tree/v2.9.5) (2022-11-17) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.4...v2.9.5) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[logs,middleware]** Create a new capture instance for each incoming request ([#9510](https://github.com/traefik/traefik/pull/9510) by [sdelicata](https://github.com/sdelicata)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[k8s/helm]** Update helm repository ([#9506](https://github.com/traefik/traefik/pull/9506) by [charlie-haley](https://github.com/charlie-haley)) | ||||
| - Enhance wording of building-testing page ([#9509](https://github.com/traefik/traefik/pull/9509) by [svx](https://github.com/svx)) | ||||
| - Add link descriptions and update wording ([#9507](https://github.com/traefik/traefik/pull/9507) by [svx](https://github.com/svx)) | ||||
| - Removes the experimental tag on the Traefik Hub header ([#9498](https://github.com/traefik/traefik/pull/9498) by [tfny](https://github.com/tfny)) | ||||
|  | ||||
| ## [v2.9.4](https://github.com/traefik/traefik/tree/v2.9.4) (2022-10-27) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.1...v2.9.4) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[acme]** Update go-acme/lego to v4.9.0 ([#9413](https://github.com/traefik/traefik/pull/9413) by [tony-defa](https://github.com/tony-defa)) | ||||
| - **[kv,redis]** Fix Redis configuration type ([#9435](https://github.com/traefik/traefik/pull/9435) by [ldez](https://github.com/ldez)) | ||||
| - **[logs,middleware,metrics]** Handle capture on redefined http.responseWriters ([#9440](https://github.com/traefik/traefik/pull/9440) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[middleware,k8s]** Remove raw cert escape in PassTLSClientCert middleware ([#9412](https://github.com/traefik/traefik/pull/9412) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[plugins]** Update Yaegi to v0.14.3 ([#9468](https://github.com/traefik/traefik/pull/9468) by [ldez](https://github.com/ldez)) | ||||
| - Remove side effect on default transport tests ([#9460](https://github.com/traefik/traefik/pull/9460) by [sdelicata](https://github.com/sdelicata)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[k8s]** Fix links to gateway API guides ([#9445](https://github.com/traefik/traefik/pull/9445) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Simplify dashboard rule example ([#9454](https://github.com/traefik/traefik/pull/9454) by [sosoba](https://github.com/sosoba)) | ||||
| - Add v2.9 to release page ([#9438](https://github.com/traefik/traefik/pull/9438) by [kevinpollet](https://github.com/kevinpollet)) | ||||
|  | ||||
| ## [v2.9.3](https://github.com/traefik/traefik/tree/v2.9.3) (2022-10-27) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.1...v2.9.3) | ||||
|  | ||||
| Release canceled. | ||||
|  | ||||
| ## [v2.9.2](https://github.com/traefik/traefik/tree/v2.9.2) (2022-10-27) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.1...v2.9.2) | ||||
|  | ||||
| Release canceled. | ||||
|  | ||||
| ## [v2.9.1](https://github.com/traefik/traefik/tree/v2.9.1) (2022-10-03) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.0-rc1...v2.9.1) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[acme,tls]** ACME Default Certificate ([#9189](https://github.com/traefik/traefik/pull/9189) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[consul,etcd,zk,kv,redis]** Update valkeyrie to v1.0.0 ([#9316](https://github.com/traefik/traefik/pull/9316) by [ldez](https://github.com/ldez)) | ||||
| - **[consulcatalog,nomad]** Support Nomad canary deployment ([#9216](https://github.com/traefik/traefik/pull/9216) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[consulcatalog]** Move consulcatalog provider to only use health apis ([#9140](https://github.com/traefik/traefik/pull/9140) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[docker]** Add support for reaching containers using host networking on Podman ([#9190](https://github.com/traefik/traefik/pull/9190) by [freundTech](https://github.com/freundTech)) | ||||
| - **[docker]** Use IPv6 address ([#9183](https://github.com/traefik/traefik/pull/9183) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[docker]** Add allowEmptyServices for Docker provider ([#8690](https://github.com/traefik/traefik/pull/8690) by [jvasseur](https://github.com/jvasseur)) | ||||
| - **[ecs]**  Add support for ECS Anywhere ([#9324](https://github.com/traefik/traefik/pull/9324) by [tuxpower](https://github.com/tuxpower)) | ||||
| - **[healthcheck]** Add a method option to the service Health Check ([#9165](https://github.com/traefik/traefik/pull/9165) by [ddtmachado](https://github.com/ddtmachado)) | ||||
| - **[http3]** Upgrade quic-go to v0.28.0 ([#9187](https://github.com/traefik/traefik/pull/9187) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[http]** Start polling HTTP provider at the beginning ([#9116](https://github.com/traefik/traefik/pull/9116) by [moutoum](https://github.com/moutoum)) | ||||
| - **[k8s/crd,plugins]** Load plugin configuration field value from Kubernetes Secret ([#9103](https://github.com/traefik/traefik/pull/9103) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[logs,tcp]** Quiet down TCP RST packet error on read operation ([#9007](https://github.com/traefik/traefik/pull/9007) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[metrics]** Add traffic size metrics ([#9208](https://github.com/traefik/traefik/pull/9208) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[middleware,pilot]** Remove Pilot support ([#9330](https://github.com/traefik/traefik/pull/9330) by [ldez](https://github.com/ldez)) | ||||
| - **[rules,tcp]** Support ALPN for TCP + TLS routers ([#8913](https://github.com/traefik/traefik/pull/8913) by [sh7dm](https://github.com/sh7dm)) | ||||
| - **[tcp,service,udp]** Make the loadbalancers servers order random ([#9037](https://github.com/traefik/traefik/pull/9037) by [qmloong](https://github.com/qmloong)) | ||||
| - **[tls]** Change default TLS options for more security ([#8951](https://github.com/traefik/traefik/pull/8951) by [ddtmachado](https://github.com/ddtmachado)) | ||||
| - **[tracing]** Add Datadog GlobalTags support ([#9266](https://github.com/traefik/traefik/pull/9266) by [sdelicata](https://github.com/sdelicata)) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[acme]** Fix ACME panic ([#9365](https://github.com/traefik/traefik/pull/9365) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[metrics]** Rework metrics overview page ([#9366](https://github.com/traefik/traefik/pull/9366) by [ddtmachado](https://github.com/ddtmachado)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.8 into v2.9 ([#9400](https://github.com/traefik/traefik/pull/9400) by [ldez](https://github.com/ldez)) | ||||
| - Merge current v2.8 into v2.9 ([#9371](https://github.com/traefik/traefik/pull/9371) by [ldez](https://github.com/ldez)) | ||||
| - Merge current v2.8 into v2.9 ([#9367](https://github.com/traefik/traefik/pull/9367) by [ldez](https://github.com/ldez)) | ||||
| - Merge current v2.8 into v2.9 ([#9350](https://github.com/traefik/traefik/pull/9350) by [ldez](https://github.com/ldez)) | ||||
| - Merge current v2.8 into v2.9 ([#9343](https://github.com/traefik/traefik/pull/9343) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge v2.8.5 into master ([#9329](https://github.com/traefik/traefik/pull/9329) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.8 into master ([#9291](https://github.com/traefik/traefik/pull/9291) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.8 into master ([#9265](https://github.com/traefik/traefik/pull/9265) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge current v2.8 into master ([#9209](https://github.com/traefik/traefik/pull/9209) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge current v2.8 into master ([#9146](https://github.com/traefik/traefik/pull/9146) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge current v2.8 into master ([#9135](https://github.com/traefik/traefik/pull/9135) by [kevinpollet](https://github.com/kevinpollet)) | ||||
|  | ||||
| ## [v2.9.0](https://github.com/traefik/traefik/tree/v2.9.0) (2022-10-03) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.0-rc1...v2.9.0) | ||||
|  | ||||
| Release canceled. | ||||
|  | ||||
| ## [v2.9.0-rc5](https://github.com/traefik/traefik/tree/v2.9.0-rc5) (2022-09-30) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.0-rc4...v2.9.0-rc5) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.8 into v2.9 ([#9400](https://github.com/traefik/traefik/pull/9400) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| ## [v2.8.8](https://github.com/traefik/traefik/tree/v2.8.8) (2022-09-30) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.7...v2.8.8) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[server]** Update golang.org/x/net to latest version ([#9398](https://github.com/traefik/traefik/pull/9398) by [tspearconquest](https://github.com/tspearconquest)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[docker]** Fix watch option description for Docker provider ([#9391](https://github.com/traefik/traefik/pull/9391) by [bhuisgen](https://github.com/bhuisgen)) | ||||
| - **[ecs]** Fix autoDiscoverClusters option documentation for ECS provider ([#9392](https://github.com/traefik/traefik/pull/9392) by [johnpekcan](https://github.com/johnpekcan)) | ||||
| - **[k8s]** Improve documentation for publishedService and IP options ([#9380](https://github.com/traefik/traefik/pull/9380) by [samip5](https://github.com/samip5)) | ||||
|  | ||||
| ## [v2.9.0-rc4](https://github.com/traefik/traefik/tree/v2.9.0-rc4) (2022-09-23) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.0-rc3...v2.9.0-rc4) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[acme]** Fix ACME panic ([#9365](https://github.com/traefik/traefik/pull/9365) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[metrics]** Rework metrics overview page ([#9366](https://github.com/traefik/traefik/pull/9366) by [ddtmachado](https://github.com/ddtmachado)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.8 into v2.9 ([#9371](https://github.com/traefik/traefik/pull/9371) by [ldez](https://github.com/ldez)) | ||||
| - Merge current v2.8 into v2.9 ([#9367](https://github.com/traefik/traefik/pull/9367) by [ldez](https://github.com/ldez)) | ||||
| - Merge current v2.8 into v2.9 ([#9350](https://github.com/traefik/traefik/pull/9350) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| ## [v2.8.7](https://github.com/traefik/traefik/tree/v2.8.7) (2022-09-23) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.5...v2.8.7) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[consulcatalog]** Fix UDP loadbalancer tags not being used with Consul Catalog ([#9357](https://github.com/traefik/traefik/pull/9357) by [t3hchipmunk](https://github.com/t3hchipmunk)) | ||||
| - **[docker,rancher,ecs,provider]** Simplify AddServer algorithm ([#9358](https://github.com/traefik/traefik/pull/9358) by [ldez](https://github.com/ldez)) | ||||
| - **[plugins]** Allow empty plugin configuration ([#9338](https://github.com/traefik/traefik/pull/9338) by [ldez](https://github.com/ldez)) | ||||
| - **[rules]** Fix query parameter matching with equal ([#9369](https://github.com/traefik/traefik/pull/9369) by [ldez](https://github.com/ldez)) | ||||
| - **[server]** Optimize websocket headers handling ([#9360](https://github.com/traefik/traefik/pull/9360) by [juliens](https://github.com/juliens)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[ecs]** Add documentation for ECS constraints option ([#9354](https://github.com/traefik/traefik/pull/9354) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[k8s/gatewayapi]** Fix link to RouteNamespaces ([#9349](https://github.com/traefik/traefik/pull/9349) by [ldez](https://github.com/ldez)) | ||||
| - Add documentation for json schema usage to validate config in the FAQ ([#9340](https://github.com/traefik/traefik/pull/9340) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Add a note on case insensitive regex matching ([#9322](https://github.com/traefik/traefik/pull/9322) by [NEwa-05](https://github.com/NEwa-05)) | ||||
|  | ||||
| ## [v2.8.6](https://github.com/traefik/traefik/tree/v2.8.6) (2022-09-23) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.5...v2.8.6) | ||||
|  | ||||
| Release canceled. | ||||
|  | ||||
| ## [v2.9.0-rc3](https://github.com/traefik/traefik/tree/v2.9.0-rc3) (2022-09-16) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.9.0-rc2...v2.9.0-rc3) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.8 into v2.9 ([#9343](https://github.com/traefik/traefik/pull/9343) by [kevinpollet](https://github.com/kevinpollet)) | ||||
|  | ||||
| ## [v2.9.0-rc1](https://github.com/traefik/traefik/tree/v2.9.0-rc2) (2022-09-14) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.0-rc1...v2.9.0-rc2) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[acme,tls]** ACME Default Certificate ([#9189](https://github.com/traefik/traefik/pull/9189) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[consul,etcd,zk,kv,redis]** Update valkeyrie to v1.0.0 ([#9316](https://github.com/traefik/traefik/pull/9316) by [ldez](https://github.com/ldez)) | ||||
| - **[consulcatalog,nomad]** Support Nomad canary deployment ([#9216](https://github.com/traefik/traefik/pull/9216) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[consulcatalog]** Move consulcatalog provider to only use health apis ([#9140](https://github.com/traefik/traefik/pull/9140) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[docker]** Add support for reaching containers using host networking on Podman ([#9190](https://github.com/traefik/traefik/pull/9190) by [freundTech](https://github.com/freundTech)) | ||||
| - **[docker]** Use IPv6 address ([#9183](https://github.com/traefik/traefik/pull/9183) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[docker]** Add allowEmptyServices for Docker provider ([#8690](https://github.com/traefik/traefik/pull/8690) by [jvasseur](https://github.com/jvasseur)) | ||||
| - **[ecs]**  Add support for ECS Anywhere ([#9324](https://github.com/traefik/traefik/pull/9324) by [tuxpower](https://github.com/tuxpower)) | ||||
| - **[healthcheck]** Add a method option to the service Health Check ([#9165](https://github.com/traefik/traefik/pull/9165) by [ddtmachado](https://github.com/ddtmachado)) | ||||
| - **[http3]** Upgrade quic-go to v0.28.0 ([#9187](https://github.com/traefik/traefik/pull/9187) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[http]** Start polling HTTP provider at the beginning ([#9116](https://github.com/traefik/traefik/pull/9116) by [moutoum](https://github.com/moutoum)) | ||||
| - **[k8s/crd,plugins]** Load plugin configuration field value from Kubernetes Secret ([#9103](https://github.com/traefik/traefik/pull/9103) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[logs,tcp]** Quiet down TCP RST packet error on read operation ([#9007](https://github.com/traefik/traefik/pull/9007) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[metrics]** Add traffic size metrics ([#9208](https://github.com/traefik/traefik/pull/9208) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[middleware,pilot]** Remove Pilot support ([#9330](https://github.com/traefik/traefik/pull/9330) by [ldez](https://github.com/ldez)) | ||||
| - **[rules,tcp]** Support ALPN for TCP + TLS routers ([#8913](https://github.com/traefik/traefik/pull/8913) by [sh7dm](https://github.com/sh7dm)) | ||||
| - **[tcp,service,udp]** Make the loadbalancers servers order random ([#9037](https://github.com/traefik/traefik/pull/9037) by [qmloong](https://github.com/qmloong)) | ||||
| - **[tls]** Change default TLS options for more security ([#8951](https://github.com/traefik/traefik/pull/8951) by [ddtmachado](https://github.com/ddtmachado)) | ||||
| - **[tracing]** Add Datadog GlobalTags support ([#9266](https://github.com/traefik/traefik/pull/9266) by [sdelicata](https://github.com/sdelicata)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge v2.8.5 into master ([#9329](https://github.com/traefik/traefik/pull/9329) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.8 into master ([#9291](https://github.com/traefik/traefik/pull/9291) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.8 into master ([#9265](https://github.com/traefik/traefik/pull/9265) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge current v2.8 into master ([#9209](https://github.com/traefik/traefik/pull/9209) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge current v2.8 into master ([#9146](https://github.com/traefik/traefik/pull/9146) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge current v2.8 into master ([#9135](https://github.com/traefik/traefik/pull/9135) by [kevinpollet](https://github.com/kevinpollet)) | ||||
|  | ||||
| ## [v2.9.0-rc1](https://github.com/traefik/traefik/tree/v2.9.0-rc1) (2022-09-14) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.0-rc1...v2.9.0-rc1) | ||||
|  | ||||
| Release canceled. | ||||
|  | ||||
| ## [v2.8.5](https://github.com/traefik/traefik/tree/v2.8.5) (2022-09-13) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.4...v2.8.5) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[plugins]** Update Yaegi to v0.14.2 ([#9327](https://github.com/traefik/traefik/pull/9327) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[server]** Fix IPv6 addr with square brackets ([#9313](https://github.com/traefik/traefik/pull/9313) by [moonlightwatch](https://github.com/moonlightwatch)) | ||||
| - **[webui,api]** Display default TLS options in the dashboard ([#9312](https://github.com/traefik/traefik/pull/9312) by [skwair](https://github.com/skwair)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[docker]** Add healthcheck timeout seconds to value ([#9306](https://github.com/traefik/traefik/pull/9306) by [fty4](https://github.com/fty4)) | ||||
| - Update deprecation notes about Pilot ([#9314](https://github.com/traefik/traefik/pull/9314) by [nmengin](https://github.com/nmengin)) | ||||
| - Added resources for businesses ([#9268](https://github.com/traefik/traefik/pull/9268) by [tomatokoolaid](https://github.com/tomatokoolaid)) | ||||
|  | ||||
| ## [v2.8.4](https://github.com/traefik/traefik/tree/v2.8.4) (2022-09-02) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.3...v2.8.4) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[docker,docker/swarm]** Fix Docker provider mem leak on operation retries ([#9288](https://github.com/traefik/traefik/pull/9288) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[middleware]** Fix retry middleware on panic ([#9284](https://github.com/traefik/traefik/pull/9284) by [ldez](https://github.com/ldez)) | ||||
| - **[plugins]** Allow Traefik starting even if plugin service is unavailable ([#9287](https://github.com/traefik/traefik/pull/9287) by [ldez](https://github.com/ldez)) | ||||
| - chore: update paerser to v0.1.9 ([#9270](https://github.com/traefik/traefik/pull/9270) by [tomMoulard](https://github.com/tomMoulard)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[acme]** Fix infoblox acme provider documentation ([#9277](https://github.com/traefik/traefik/pull/9277) by [ldez](https://github.com/ldez)) | ||||
| - **[k8s/crd]** Fix serversTransport CRD documentation ([#9283](https://github.com/traefik/traefik/pull/9283) by [cuishuang](https://github.com/cuishuang)) | ||||
| - **[k8s/crd]** Fix k8s for example for rootCAs serversTransport ([#9274](https://github.com/traefik/traefik/pull/9274) by [ben-krieger](https://github.com/ben-krieger)) | ||||
| - **[k8s]** Add missing networking apiGroup in Kubernetes RBACs examples and references ([#9295](https://github.com/traefik/traefik/pull/9295) by [fibsifan](https://github.com/fibsifan)) | ||||
| - Update deprecation notes about Pilot ([#9300](https://github.com/traefik/traefik/pull/9300) by [nmengin](https://github.com/nmengin)) | ||||
|  | ||||
| ## [v2.8.3](https://github.com/traefik/traefik/tree/v2.8.3) (2022-08-12) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.2...v2.8.3) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[file]** Update paerser to v0.1.8 ([#9258](https://github.com/traefik/traefik/pull/9258) by [ldez](https://github.com/ldez)) | ||||
| - **[marathon]** Add missing context in backoff for Marathon ([#9246](https://github.com/traefik/traefik/pull/9246) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| ## [v2.8.2](https://github.com/traefik/traefik/tree/v2.8.2) (2022-08-11) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.1...v2.8.2) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[k8s/ingress,k8s]** Place namespace before name in router key for Ingress ([#9221](https://github.com/traefik/traefik/pull/9221) by [longshine](https://github.com/longshine)) | ||||
| - **[kv]** Update valkeyrie to a9a70ee ([#9243](https://github.com/traefik/traefik/pull/9243) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[logs,middleware,tracing]** Remove request dump from IPWhitelist debug log and tracing message ([#9244](https://github.com/traefik/traefik/pull/9244) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[metrics]** Control allocation and copy of labelNamesValues type ([#9241](https://github.com/traefik/traefik/pull/9241) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[metrics]** Fix service up gauge for Prometheus metrics ([#9197](https://github.com/traefik/traefik/pull/9197) by [juliens](https://github.com/juliens)) | ||||
| - **[plugins]** Bump paerser to v0.1.6 ([#9224](https://github.com/traefik/traefik/pull/9224) by [ldez](https://github.com/ldez)) | ||||
| - **[yaml]** Add missing inline tag for YAML serialization ([#9182](https://github.com/traefik/traefik/pull/9182) by [kevinpollet](https://github.com/kevinpollet)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[k8s]** Fix wording of default behavior for namespaces option ([#9222](https://github.com/traefik/traefik/pull/9222) by [markormesher](https://github.com/markormesher)) | ||||
| - **[k8s]** Add getting started guide for Kubernetes ([#9163](https://github.com/traefik/traefik/pull/9163) by [moutoum](https://github.com/moutoum)) | ||||
| - **[plugins]** Remove Traefik Pilot and add a Traefik Plugins Catalog page ([#9171](https://github.com/traefik/traefik/pull/9171) by [sdelicata](https://github.com/sdelicata)) | ||||
| - Update Thank You page with proper branding and grammar fixes ([#9203](https://github.com/traefik/traefik/pull/9203) by [tfny](https://github.com/tfny)) | ||||
| - Update CONTRIBUTING.md to contain all information in one place ([#9192](https://github.com/traefik/traefik/pull/9192) by [tfny](https://github.com/tfny)) | ||||
| - Update the PR guidelines in Contributing docs ([#9179](https://github.com/traefik/traefik/pull/9179) by [tfny](https://github.com/tfny)) | ||||
|  | ||||
| ## [v2.8.1](https://github.com/traefik/traefik/tree/v2.8.1) (2022-07-11) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.0...v2.8.1) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[kv]** Upgrade valkeyrie to v0.4.1 ([#9161](https://github.com/traefik/traefik/pull/9161) by [moutoum](https://github.com/moutoum)) | ||||
| - **[middleware,metrics]** Improve performances when Prometheus metrics are enabled ([#9168](https://github.com/traefik/traefik/pull/9168) by [juliens](https://github.com/juliens)) | ||||
| - **[middleware]** Support forwarded websocket protocol in RedirectScheme ([#9159](https://github.com/traefik/traefik/pull/9159) by [moutoum](https://github.com/moutoum)) | ||||
|  | ||||
| **Documentation:** | ||||
| - Update the language for advocating page ([#9169](https://github.com/traefik/traefik/pull/9169) by [tfny](https://github.com/tfny)) | ||||
| - Add callout for anyone using Traefik to manage commercial applications ([#9152](https://github.com/traefik/traefik/pull/9152) by [tomatokoolaid](https://github.com/tomatokoolaid)) | ||||
| - Update deprecation notices ([#9149](https://github.com/traefik/traefik/pull/9149) by [ddtmachado](https://github.com/ddtmachado)) | ||||
|  | ||||
| ## [v2.8.0](https://github.com/traefik/traefik/tree/v2.8.0) (2022-06-29) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.0-rc1...v2.8.0) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[consul,consulcatalog]** Support multiple namespaces for Consul and ConsulCatalog providers ([#8979](https://github.com/traefik/traefik/pull/8979) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[http3]** Upgrade quic-go to v0.27.0 ([#8922](https://github.com/traefik/traefik/pull/8922) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[http3]** Upgrade quic-go to v0.26.0 ([#8874](https://github.com/traefik/traefik/pull/8874) by [sylr](https://github.com/sylr)) | ||||
| - **[logs]** Add destination address to debug log ([#9032](https://github.com/traefik/traefik/pull/9032) by [qmloong](https://github.com/qmloong)) | ||||
| - **[middleware,provider,tls]** Deprecate caOptional option in client TLS configuration ([#8960](https://github.com/traefik/traefik/pull/8960) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[middleware]** Support URL replacement in errors middleware ([#8956](https://github.com/traefik/traefik/pull/8956) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[middleware]** Allow config of additional CircuitBreaker params ([#8907](https://github.com/traefik/traefik/pull/8907) by [aidy](https://github.com/aidy)) | ||||
| - **[provider]** Implement Traefik provider for Nomad orchestrator ([#9018](https://github.com/traefik/traefik/pull/9018) by [shoenig](https://github.com/shoenig)) | ||||
| - **[server]** Allow HTTP/2 max concurrent stream configuration ([#8781](https://github.com/traefik/traefik/pull/8781) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[tls,k8s/crd]** Support certificates configuration in TLSStore CRD ([#8976](https://github.com/traefik/traefik/pull/8976) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[webui,pilot,hub]** Add Traefik Hub button and deprecate Pilot ([#9091](https://github.com/traefik/traefik/pull/9091) by [ldez](https://github.com/ldez)) | ||||
| - **[webui,plugins]** Reach the catalog of plugins from the Traefik dashboard ([#9055](https://github.com/traefik/traefik/pull/9055) by [seedy](https://github.com/seedy)) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[nomad]** Use configured token in the Nomad client ([#9111](https://github.com/traefik/traefik/pull/9111) by [kevinpollet](https://github.com/kevinpollet)) | ||||
|  | ||||
| **Documentation:** | ||||
| - Prepare release v2.8.0-rc2 ([#9134](https://github.com/traefik/traefik/pull/9134) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Prepare release v2.8.0-rc1 ([#9097](https://github.com/traefik/traefik/pull/9097) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.7 into v2.8 ([#9142](https://github.com/traefik/traefik/pull/9142) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.7 into v2.8 ([#9133](https://github.com/traefik/traefik/pull/9133) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.7 into master ([#9095](https://github.com/traefik/traefik/pull/9095) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.7 into master ([#9085](https://github.com/traefik/traefik/pull/9085) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.7 into master ([#9060](https://github.com/traefik/traefik/pull/9060) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.7 into master ([#9052](https://github.com/traefik/traefik/pull/9052) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.7 into master ([#8959](https://github.com/traefik/traefik/pull/8959) by [tomMoulard](https://github.com/tomMoulard)) | ||||
|  | ||||
| ## [v2.7.3](https://github.com/traefik/traefik/tree/v2.7.3) (2022-06-29) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.7.2...v2.7.3) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[metrics]** Ensure Datadog client is cleanly stopped ([#9137](https://github.com/traefik/traefik/pull/9137) by [jbdoumenjou](https://github.com/jbdoumenjou)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[middleware,k8s/crd]** Add documentation for main, SANs and plugin CRD fields ([#9136](https://github.com/traefik/traefik/pull/9136) by [mloiseleur](https://github.com/mloiseleur)) | ||||
|  | ||||
| ## [v2.8.0-rc2](https://github.com/traefik/traefik/tree/v2.8.0-rc2) (2022-06-27) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.8.0-rc1...v2.8.0-rc2) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[nomad]** Use configured token in the Nomad client ([#9111](https://github.com/traefik/traefik/pull/9111) by [kevinpollet](https://github.com/kevinpollet)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.7 into v2.8 ([#9133](https://github.com/traefik/traefik/pull/9133) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| ## [v2.7.2](https://github.com/traefik/traefik/tree/v2.7.2) (2022-06-27) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.7.1...v2.7.2) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[healthcheck,service]** Do not make multiple requests to the same URL for balancer healthcheck  ([#8632](https://github.com/traefik/traefik/pull/8632) by [TPXP](https://github.com/TPXP)) | ||||
| - **[healthcheck,service]** Add log when missing path in health check ([#9104](https://github.com/traefik/traefik/pull/9104) by [moutoum](https://github.com/moutoum)) | ||||
| - **[k8s/gatewayapi]** Allow multiple listeners on same port in Gateway API provider ([#9107](https://github.com/traefik/traefik/pull/9107) by [burner-account](https://github.com/burner-account)) | ||||
| - **[middleware]** RedirectScheme redirects based on X-Forwarded-Proto header ([#9121](https://github.com/traefik/traefik/pull/9121) by [moutoum](https://github.com/moutoum)) | ||||
| - **[plugins]** Update yaegi to v0.13.0 ([#9118](https://github.com/traefik/traefik/pull/9118) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[rules]** Fix HostRegexp and Query muxers ([#9131](https://github.com/traefik/traefik/pull/9131) by [juliens](https://github.com/juliens)) | ||||
| - **[tracing]** Update DataDog tracing dependency to v1.38.1 ([#9105](https://github.com/traefik/traefik/pull/9105) by [kevinpollet](https://github.com/kevinpollet)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[acme,k8s/crd]** Add documentation to Traefik CRD properties ([#9096](https://github.com/traefik/traefik/pull/9096) by [mloiseleur](https://github.com/mloiseleur)) | ||||
| - **[middleware]** Add missing info.serialNumber option to PassTLSClientCert middleware ([#9115](https://github.com/traefik/traefik/pull/9115) by [miteshjadia](https://github.com/miteshjadia)) | ||||
| - **[tcp]** Add a note on how to handle server first protocols ([#9002](https://github.com/traefik/traefik/pull/9002) by [romantomjak](https://github.com/romantomjak)) | ||||
| - Update to improve info section relevance ([#9130](https://github.com/traefik/traefik/pull/9130) by [tomatokoolaid](https://github.com/tomatokoolaid)) | ||||
| - Added useful links for commercial applications ([#9129](https://github.com/traefik/traefik/pull/9129) by [tomatokoolaid](https://github.com/tomatokoolaid)) | ||||
|  | ||||
| ## [v2.8.0-rc1](https://github.com/traefik/traefik/tree/v2.8.0-rc1) (2022-06-13) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.7.0-rc1...v2.8.0-rc1) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[consul,consulcatalog]** Support multiple namespaces for Consul and ConsulCatalog providers ([#8979](https://github.com/traefik/traefik/pull/8979) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[http3]** Upgrade quic-go to v0.27.0 ([#8922](https://github.com/traefik/traefik/pull/8922) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[http3]** Upgrade quic-go to v0.26.0 ([#8874](https://github.com/traefik/traefik/pull/8874) by [sylr](https://github.com/sylr)) | ||||
| - **[logs]** Add destination address to debug log ([#9032](https://github.com/traefik/traefik/pull/9032) by [qmloong](https://github.com/qmloong)) | ||||
| - **[middleware,provider,tls]** Deprecate caOptional option in client TLS configuration ([#8960](https://github.com/traefik/traefik/pull/8960) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[middleware]** Support URL replacement in errors middleware ([#8956](https://github.com/traefik/traefik/pull/8956) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[middleware]** Allow config of additional CircuitBreaker params ([#8907](https://github.com/traefik/traefik/pull/8907) by [aidy](https://github.com/aidy)) | ||||
| - **[provider]** Implement Traefik provider for Nomad orchestrator ([#9018](https://github.com/traefik/traefik/pull/9018) by [shoenig](https://github.com/shoenig)) | ||||
| - **[server]** Allow HTTP/2 max concurrent stream configuration ([#8781](https://github.com/traefik/traefik/pull/8781) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[tls,k8s/crd]** Support certificates configuration in TLSStore CRD ([#8976](https://github.com/traefik/traefik/pull/8976) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[webui,pilot,hub]** Add Traefik Hub button and deprecate Pilot ([#9091](https://github.com/traefik/traefik/pull/9091) by [ldez](https://github.com/ldez)) | ||||
| - **[webui,plugins]** Reach the catalog of plugins from the Traefik dashboard ([#9055](https://github.com/traefik/traefik/pull/9055) by [seedy](https://github.com/seedy)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.7 into master ([#9095](https://github.com/traefik/traefik/pull/9095) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.7 into master ([#9085](https://github.com/traefik/traefik/pull/9085) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.7 into master ([#9060](https://github.com/traefik/traefik/pull/9060) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.7 into master ([#9052](https://github.com/traefik/traefik/pull/9052) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.7 into master ([#8959](https://github.com/traefik/traefik/pull/8959) by [tomMoulard](https://github.com/tomMoulard)) | ||||
|  | ||||
| ## [v2.7.1](https://github.com/traefik/traefik/tree/v2.7.1) (2022-06-13) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.7.0...v2.7.1) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[acme]** Update go-acme/lego to v4.7.0 ([#9065](https://github.com/traefik/traefik/pull/9065) by [ldez](https://github.com/ldez)) | ||||
| - **[logs]** Fix invalid placeholder in log message ([#9084](https://github.com/traefik/traefik/pull/9084) by [ldez](https://github.com/ldez)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[hub]** Hub documentation ([#9090](https://github.com/traefik/traefik/pull/9090) by [ldez](https://github.com/ldez)) | ||||
| - **[k8s,k8s/gatewayapi]** Update Gateway API link from v1alpha1 to v1alpha2 ([#9083](https://github.com/traefik/traefik/pull/9083) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[k8s,k8s/gatewayapi]** Update Gateway API links ([#9058](https://github.com/traefik/traefik/pull/9058) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[middleware]** Fix typo in stripPrefix middleware docs ([#9051](https://github.com/traefik/traefik/pull/9051) by [rbarbey](https://github.com/rbarbey)) | ||||
| - **[rules]** Fix rule expression rendering ([#9076](https://github.com/traefik/traefik/pull/9076) by [ldez](https://github.com/ldez)) | ||||
| - Update the link for contributor swag ([#9056](https://github.com/traefik/traefik/pull/9056) by [tfny](https://github.com/tfny)) | ||||
| - Fix Traefik version s/2.6/2.7/ ([#9047](https://github.com/traefik/traefik/pull/9047) by [mpl](https://github.com/mpl)) | ||||
| - Update the contributing docs for clarity and to encourage community activity ([#9035](https://github.com/traefik/traefik/pull/9035) by [tfny](https://github.com/tfny)) | ||||
|  | ||||
| ## [v2.7.0](https://github.com/traefik/traefik/tree/v2.7.0) (2022-05-24) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.7.0-rc1...v2.7.0) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[consulcatalog]** Watch for Consul events to rebuild the dynamic configuration ([#8476](https://github.com/traefik/traefik/pull/8476) by [JasonWangA](https://github.com/JasonWangA)) | ||||
| - **[healthcheck]** Add Failover service ([#8825](https://github.com/traefik/traefik/pull/8825) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[http3]** Configure advertised port using h3 server option ([#8778](https://github.com/traefik/traefik/pull/8778) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[http3]** Upgrade quic-go to v0.25.0 ([#8760](https://github.com/traefik/traefik/pull/8760) by [sylr](https://github.com/sylr)) | ||||
| - **[hub]** Add Traefik Hub Integration (Experimental Feature) ([#8837](https://github.com/traefik/traefik/pull/8837) by [jbdoumenjou](https://github.com/jbdoumenjou)) | ||||
| - **[k8s/crd,k8s]** Allow empty services in Kubernetes CRD ([#8802](https://github.com/traefik/traefik/pull/8802) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[metrics]** Support InfluxDB v2 metrics backend ([#8250](https://github.com/traefik/traefik/pull/8250) by [sh7dm](https://github.com/sh7dm)) | ||||
| - **[plugins]** Remove Pilot token setup constraint to use plugins ([#8869](https://github.com/traefik/traefik/pull/8869) by [ldez](https://github.com/ldez)) | ||||
| - **[provider]** Refactor configuration reload/throttling ([#6633](https://github.com/traefik/traefik/pull/6633) by [rkojedzinszky](https://github.com/rkojedzinszky)) | ||||
| - **[rules,tcp]** Add HostSNIRegexp rule matcher for TCP ([#8849](https://github.com/traefik/traefik/pull/8849) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[tcp]** Add muxer for TCP Routers ([#8182](https://github.com/traefik/traefik/pull/8182) by [dtomcej](https://github.com/dtomcej)) | ||||
| - **[webui,pilot]** Add Traefik Hub access and remove Pilot access ([#8848](https://github.com/traefik/traefik/pull/8848) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[webui]** Add a link to service on router detail view ([#8821](https://github.com/traefik/traefik/pull/8821) by [Tchoupinax](https://github.com/Tchoupinax)) | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[hub]** Skip Provide when TLS is nil ([#9031](https://github.com/traefik/traefik/pull/9031) by [ldez](https://github.com/ldez)) | ||||
| - **[tcp]** Fix TCP-TLS/HTTPS routing precedence ([#9024](https://github.com/traefik/traefik/pull/9024) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[webui,hub]** Use dedicated entrypoint for the tunnels ([#9023](https://github.com/traefik/traefik/pull/9023) by [youkoulayley](https://github.com/youkoulayley)) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[hub]** Fix Traefik Hub TLS documentation ([#8883](https://github.com/traefik/traefik/pull/8883) by [jbdoumenjou](https://github.com/jbdoumenjou)) | ||||
| - Add a Feature Deprecation page ([#8868](https://github.com/traefik/traefik/pull/8868) by [ddtmachado](https://github.com/ddtmachado)) | ||||
| - Prepare release v2.7.0-rc1 ([#8879](https://github.com/traefik/traefik/pull/8879) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Prepare release v2.7.0-rc2 ([#8900](https://github.com/traefik/traefik/pull/8900) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.6 into v2.7 ([#8984](https://github.com/traefik/traefik/pull/8984) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge current v2.6 into v2.7 ([#8958](https://github.com/traefik/traefik/pull/8958) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into v2.7 ([#8899](https://github.com/traefik/traefik/pull/8899) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.6 into master ([#8877](https://github.com/traefik/traefik/pull/8877) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.6 into master ([#8865](https://github.com/traefik/traefik/pull/8865) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8832](https://github.com/traefik/traefik/pull/8832) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8793](https://github.com/traefik/traefik/pull/8793) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8777](https://github.com/traefik/traefik/pull/8777) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8757](https://github.com/traefik/traefik/pull/8757) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8754](https://github.com/traefik/traefik/pull/8754) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8736](https://github.com/traefik/traefik/pull/8736) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge current v2.6 into master ([#8689](https://github.com/traefik/traefik/pull/8689) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8666](https://github.com/traefik/traefik/pull/8666) by [tomMoulard](https://github.com/tomMoulard)) | ||||
|  | ||||
| ## [v2.6.7](https://github.com/traefik/traefik/tree/v2.6.7) (2022-05-23) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.6.6...v2.6.7) | ||||
|  | ||||
| @@ -44,6 +735,15 @@ Release canceled. | ||||
|  | ||||
| Release canceled. | ||||
|  | ||||
| ## [v2.7.0-rc2](https://github.com/traefik/traefik/tree/v2.7.0-rc2) (2022-03-29) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.7.0-rc1...v2.7.0-rc2) | ||||
|  | ||||
| **Documentation:** | ||||
| - **[hub]** Fix Traefik Hub TLS documentation ([#8883](https://github.com/traefik/traefik/pull/8883) by [jbdoumenjou](https://github.com/jbdoumenjou)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.6 into v2.7 ([#8899](https://github.com/traefik/traefik/pull/8899) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| ## [v2.6.3](https://github.com/traefik/traefik/tree/v2.6.3) (2022-03-28) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.6.2...v2.6.3) | ||||
|  | ||||
| @@ -51,6 +751,39 @@ Release canceled. | ||||
| - **[plugins]** Fix slice parsing for plugins ([#8886](https://github.com/traefik/traefik/pull/8886) by [ldez](https://github.com/ldez)) | ||||
| - **[tls]** Return TLS unrecognized_name error when no certificate is available ([#8893](https://github.com/traefik/traefik/pull/8893) by [rtribotte](https://github.com/rtribotte)) | ||||
|  | ||||
| ## [v2.7.0-rc1](https://github.com/traefik/traefik/tree/v2.7.0-rc1) (2022-03-24) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.6.0-rc1...v2.7.0-rc1) | ||||
|  | ||||
| **Enhancements:** | ||||
| - **[consulcatalog]** Watch for Consul events to rebuild the dynamic configuration ([#8476](https://github.com/traefik/traefik/pull/8476) by [JasonWangA](https://github.com/JasonWangA)) | ||||
| - **[healthcheck]** Add Failover service ([#8825](https://github.com/traefik/traefik/pull/8825) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[http3]** Configure advertised port using h3 server option ([#8778](https://github.com/traefik/traefik/pull/8778) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - **[http3]** Upgrade quic-go to v0.25.0 ([#8760](https://github.com/traefik/traefik/pull/8760) by [sylr](https://github.com/sylr)) | ||||
| - **[hub]** Add Traefik Hub Integration (Experimental Feature) ([#8837](https://github.com/traefik/traefik/pull/8837) by [jbdoumenjou](https://github.com/jbdoumenjou)) | ||||
| - **[k8s/crd,k8s]** Allow empty services in Kubernetes CRD ([#8802](https://github.com/traefik/traefik/pull/8802) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[metrics]** Support InfluxDB v2 metrics backend ([#8250](https://github.com/traefik/traefik/pull/8250) by [sh7dm](https://github.com/sh7dm)) | ||||
| - **[plugins]** Remove Pilot token setup constraint to use plugins ([#8869](https://github.com/traefik/traefik/pull/8869) by [ldez](https://github.com/ldez)) | ||||
| - **[provider]** Refactor configuration reload/throttling ([#6633](https://github.com/traefik/traefik/pull/6633) by [rkojedzinszky](https://github.com/rkojedzinszky)) | ||||
| - **[rules,tcp]** Add HostSNIRegexp rule matcher for TCP ([#8849](https://github.com/traefik/traefik/pull/8849) by [rtribotte](https://github.com/rtribotte)) | ||||
| - **[tcp]** Add muxer for TCP Routers ([#8182](https://github.com/traefik/traefik/pull/8182) by [dtomcej](https://github.com/dtomcej)) | ||||
| - **[webui,pilot]** Add Traefik Hub access and remove Pilot access ([#8848](https://github.com/traefik/traefik/pull/8848) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - **[webui]** Add a link to service on router detail view ([#8821](https://github.com/traefik/traefik/pull/8821) by [Tchoupinax](https://github.com/Tchoupinax)) | ||||
|  | ||||
| **Documentation:** | ||||
| - Add a Feature Deprecation page ([#8868](https://github.com/traefik/traefik/pull/8868) by [ddtmachado](https://github.com/ddtmachado)) | ||||
|  | ||||
| **Misc:** | ||||
| - Merge current v2.6 into master ([#8877](https://github.com/traefik/traefik/pull/8877) by [rtribotte](https://github.com/rtribotte)) | ||||
| - Merge current v2.6 into master ([#8865](https://github.com/traefik/traefik/pull/8865) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8832](https://github.com/traefik/traefik/pull/8832) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8793](https://github.com/traefik/traefik/pull/8793) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8777](https://github.com/traefik/traefik/pull/8777) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8757](https://github.com/traefik/traefik/pull/8757) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8754](https://github.com/traefik/traefik/pull/8754) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8736](https://github.com/traefik/traefik/pull/8736) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge current v2.6 into master ([#8689](https://github.com/traefik/traefik/pull/8689) by [tomMoulard](https://github.com/tomMoulard)) | ||||
| - Merge current v2.6 into master ([#8666](https://github.com/traefik/traefik/pull/8666) by [tomMoulard](https://github.com/tomMoulard)) | ||||
|  | ||||
| ## [v2.6.2](https://github.com/traefik/traefik/tree/v2.6.2) (2022-03-24) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.6.1...v2.6.2) | ||||
|  | ||||
| @@ -405,7 +1138,6 @@ Release canceled. | ||||
| - Merge current v2.4 into master ([#7748](https://github.com/traefik/traefik/pull/7748) by [kevinpollet](https://github.com/kevinpollet)) | ||||
| - Merge current v2.4 into master ([#7728](https://github.com/traefik/traefik/pull/7728) by [mmatur](https://github.com/mmatur)) | ||||
|  | ||||
|  | ||||
| ## [v2.4.14](https://github.com/traefik/traefik/tree/v2.4.14) (2021-08-16) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v2.4.13...v2.4.14) | ||||
|  | ||||
| @@ -3221,7 +3953,6 @@ Same changelog as v2.0.3. | ||||
| ## [v1.7.0-rc2](https://github.com/traefik/traefik/tree/v1.7.0-rc2) (2018-07-17) | ||||
| [All Commits](https://github.com/traefik/traefik/compare/v1.7.0-rc1...v1.7.0-rc2) | ||||
|  | ||||
|  | ||||
| **Bug fixes:** | ||||
| - **[acme,provider]** Create init method on provider interface ([#3580](https://github.com/traefik/traefik/pull/3580) by [Juliens](https://github.com/Juliens)) | ||||
| - **[acme]** Serve TLS-Challenge certificate in first ([#3605](https://github.com/traefik/traefik/pull/3605) by [nmengin](https://github.com/nmengin)) | ||||
| @@ -4231,7 +4962,7 @@ Same changelog as v2.0.3. | ||||
| - **[acme]** Dumpcerts.sh: fixed sed, extracted domain keys ([#2161](https://github.com/traefik/traefik/pull/2161) by [sjawhar](https://github.com/sjawhar)) | ||||
| - Merge current v1.4 into master  ([#2469](https://github.com/traefik/traefik/pull/2469) by [ldez](https://github.com/ldez)) | ||||
| - Revert "Merge v1.4.2 into master" ([#2414](https://github.com/traefik/traefik/pull/2414) by [ldez](https://github.com/ldez)) | ||||
| -  Merge v1.4.3 into master ([#2406](https://github.com/traefik/traefik/pull/2406) by [ldez](https://github.com/ldez)) | ||||
| - Merge v1.4.3 into master ([#2406](https://github.com/traefik/traefik/pull/2406) by [ldez](https://github.com/ldez)) | ||||
| - Merge v1.4.2 into master ([#2358](https://github.com/traefik/traefik/pull/2358) by [ldez](https://github.com/ldez)) | ||||
| - Merge v1.4.3 into master ([#2415](https://github.com/traefik/traefik/pull/2415) by [ldez](https://github.com/ldez)) | ||||
| - Merge v1.4.1 into master  ([#2318](https://github.com/traefik/traefik/pull/2318) by [ldez](https://github.com/ldez)) | ||||
| @@ -5580,7 +6311,7 @@ Same changelog as v2.0.3. | ||||
| - Fix k8s watch [\#573](https://github.com/traefik/traefik/pull/573) ([errm](https://github.com/errm)) | ||||
| - Add requirements.txt for netlify [\#567](https://github.com/traefik/traefik/pull/567) ([emilevauge](https://github.com/emilevauge)) | ||||
| - Merge v1.0.1 master [\#565](https://github.com/traefik/traefik/pull/565) ([emilevauge](https://github.com/emilevauge)) | ||||
| -  Move webui to FountainJS with Webpack [\#558](https://github.com/traefik/traefik/pull/558) ([micaelmbagira](https://github.com/micaelmbagira)) | ||||
| - Move webui to FountainJS with Webpack [\#558](https://github.com/traefik/traefik/pull/558) ([micaelmbagira](https://github.com/micaelmbagira)) | ||||
| - Add global InsecureSkipVerify option to disable certificate checking [\#557](https://github.com/traefik/traefik/pull/557) ([stuart-c](https://github.com/stuart-c)) | ||||
| - Move version.go in its own package… [\#553](https://github.com/traefik/traefik/pull/553) ([vdemeester](https://github.com/vdemeester)) | ||||
| - Upgrade libkermit and dependencies [\#552](https://github.com/traefik/traefik/pull/552) ([vdemeester](https://github.com/vdemeester)) | ||||
| @@ -5803,7 +6534,7 @@ Same changelog as v2.0.3. | ||||
| - Fix k8s watch [\#573](https://github.com/traefik/traefik/pull/573) ([errm](https://github.com/errm)) | ||||
| - Add requirements.txt for netlify [\#567](https://github.com/traefik/traefik/pull/567) ([emilevauge](https://github.com/emilevauge)) | ||||
| - Merge v1.0.1 master [\#565](https://github.com/traefik/traefik/pull/565) ([emilevauge](https://github.com/emilevauge)) | ||||
| -  Move webui to FountainJS with Webpack [\#558](https://github.com/traefik/traefik/pull/558) ([micaelmbagira](https://github.com/micaelmbagira)) | ||||
| - Move webui to FountainJS with Webpack [\#558](https://github.com/traefik/traefik/pull/558) ([micaelmbagira](https://github.com/micaelmbagira)) | ||||
| - Add global InsecureSkipVerify option to disable certificate checking [\#557](https://github.com/traefik/traefik/pull/557) ([stuart-c](https://github.com/stuart-c)) | ||||
| - Move version.go in its own package… [\#553](https://github.com/traefik/traefik/pull/553) ([vdemeester](https://github.com/vdemeester)) | ||||
| - Upgrade libkermit and dependencies [\#552](https://github.com/traefik/traefik/pull/552) ([vdemeester](https://github.com/vdemeester)) | ||||
| @@ -5964,7 +6695,3 @@ Same changelog as v2.0.3. | ||||
| - Fix travis tag check [\#422](https://github.com/traefik/traefik/pull/422) ([emilevauge](https://github.com/emilevauge)) | ||||
| - log info about TOML configuration file using [\#420](https://github.com/traefik/traefik/pull/420) ([cocap10](https://github.com/cocap10)) | ||||
| - Doc about skipping some integration tests with '-check.f ConsulCatalogSuite' [\#418](https://github.com/traefik/traefik/pull/418) ([samber](https://github.com/samber)) | ||||
|  | ||||
|  | ||||
|  | ||||
| \* *This Change Log was automatically generated by [gcg](https://github.com/ldez/gcg)* | ||||
|   | ||||
| @@ -30,18 +30,18 @@ Project maintainers have the right and responsibility to remove, edit, or reject | ||||
|  | ||||
| ## Scope | ||||
|  | ||||
| This Code of Conduct applies both within project spaces and in public spaces when an individual is representing the project or our community.  | ||||
| This Code of Conduct applies both within project spaces and in public spaces when an individual is representing the project or our community. | ||||
|  | ||||
| Examples of representing a project or community include using an official project e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event.  | ||||
| Examples of representing a project or community include using an official project e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event. | ||||
| Representation of a project may be further defined and clarified by project maintainers. | ||||
|  | ||||
| ## Enforcement | ||||
|  | ||||
| Instances of abusive, harassing, or otherwise unacceptable behavior may be reported by contacting the project team at contact@traefik.io | ||||
|  | ||||
| All complaints will be reviewed and investigated and will result in a response that is deemed necessary and appropriate to the circumstances.  | ||||
| All complaints will be reviewed and investigated and will result in a response that is deemed necessary and appropriate to the circumstances. | ||||
|  | ||||
| The project team is obligated to maintain confidentiality with regard to the reporter of an incident.  | ||||
| The project team is obligated to maintain confidentiality with regard to the reporter of an incident. | ||||
|  | ||||
| Further details of specific enforcement policies may be posted separately. | ||||
|  | ||||
|   | ||||
| @@ -2,8 +2,10 @@ | ||||
|  | ||||
| Here are some guidelines that should help to start contributing to the project. | ||||
|  | ||||
| - [Submitting pull Requests](https://github.com/traefik/contributors-guide/blob/master/pr_guidelines.md) | ||||
| - [Submitting pull Requests](https://doc.traefik.io/traefik/contributing/submitting-pull-requests/) | ||||
| - [Submitting issues](https://doc.traefik.io/traefik/contributing/submitting-issues/) | ||||
| - [Submitting security issues](docs/content/contributing/submitting-security-issues.md) | ||||
| - [Submitting security issues](https://doc.traefik.io/traefik/contributing/submitting-security-issues/) | ||||
| - [Advocating for Traefik](https://doc.traefik.io/traefik/contributing/advocating/) | ||||
| - [Triage Process](https://github.com/traefik/contributors-guide/blob/master/issue_triage.md) | ||||
|  | ||||
| If you are willing to become a maintainer of the project, please take a look at the [maintainers guidelines](docs/content/contributing/maintainers-guidelines.md). | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| The MIT License (MIT) | ||||
|  | ||||
| Copyright (c) 2016-2020 Containous SAS; 2020-2022 Traefik Labs | ||||
| Copyright (c) 2016-2020 Containous SAS; 2020-2023 Traefik Labs | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
|   | ||||
							
								
								
									
										13
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								Makefile
									
									
									
									
									
								
							| @@ -14,6 +14,7 @@ TRAEFIK_IMAGE := $(if $(REPONAME),$(REPONAME),"traefik/traefik") | ||||
| INTEGRATION_OPTS := $(if $(MAKE_DOCKER_HOST),-e "DOCKER_HOST=$(MAKE_DOCKER_HOST)",-v "/var/run/docker.sock:/var/run/docker.sock") | ||||
| DOCKER_BUILD_ARGS := $(if $(DOCKER_VERSION), "--build-arg=DOCKER_VERSION=$(DOCKER_VERSION)",) | ||||
|  | ||||
| # only used when running in docker | ||||
| TRAEFIK_ENVS := \ | ||||
| 	-e OS_ARCH_ARG \ | ||||
| 	-e OS_PLATFORM_ARG \ | ||||
| @@ -23,7 +24,7 @@ TRAEFIK_ENVS := \ | ||||
| 	-e CODENAME \ | ||||
| 	-e TESTDIRS \ | ||||
| 	-e CI \ | ||||
| 	-e CONTAINER=DOCKER		# Indicator for integration tests that we are running inside a container. | ||||
| 	-e IN_DOCKER=true		# Indicator for integration tests that we are running inside a container. | ||||
|  | ||||
| TRAEFIK_MOUNT := -v "$(CURDIR)/dist:/go/src/github.com/traefik/traefik/dist" | ||||
| DOCKER_RUN_OPTS := $(TRAEFIK_ENVS) $(TRAEFIK_MOUNT) "$(TRAEFIK_DEV_IMAGE)" | ||||
| @@ -34,8 +35,6 @@ DOCKER_RUN_TRAEFIK_NOTTY := docker run $(INTEGRATION_OPTS) $(if $(DOCKER_NON_INT | ||||
|  | ||||
| IN_DOCKER ?= true | ||||
|  | ||||
| PLATFORM_URL := $(if $(PLATFORM_URL),$(PLATFORM_URL),"https://pilot.traefik.io") | ||||
|  | ||||
| .PHONY: default | ||||
| default: binary | ||||
|  | ||||
| @@ -60,7 +59,7 @@ endif | ||||
| ## Build WebUI Docker image | ||||
| .PHONY: build-webui-image | ||||
| build-webui-image: | ||||
| 	docker build -t traefik-webui --build-arg ARG_PLATFORM_URL=$(PLATFORM_URL) -f webui/Dockerfile webui | ||||
| 	docker build -t traefik-webui -f webui/Dockerfile webui | ||||
|  | ||||
| ## Clean WebUI static generated assets | ||||
| .PHONY: clean-webui | ||||
| @@ -104,7 +103,7 @@ crossbinary-default-parallel: | ||||
| test: build-dev-image | ||||
| 	-docker network create traefik-test-network --driver bridge --subnet 172.31.42.0/24 | ||||
| 	trap 'docker network rm traefik-test-network' EXIT; \ | ||||
| 	$(if $(IN_DOCKER),$(DOCKER_RUN_TRAEFIK_TEST),) ./script/make.sh generate test-unit binary test-integration | ||||
| 	$(if $(IN_DOCKER),$(DOCKER_RUN_TRAEFIK_TEST)) ./script/make.sh generate test-unit binary test-integration | ||||
|  | ||||
| ## Run the unit tests | ||||
| .PHONY: test-unit | ||||
| @@ -118,7 +117,7 @@ test-unit: build-dev-image | ||||
| test-integration: build-dev-image | ||||
| 	-docker network create traefik-test-network --driver bridge --subnet 172.31.42.0/24 | ||||
| 	trap 'docker network rm traefik-test-network' EXIT; \ | ||||
| 	$(if $(IN_DOCKER),$(DOCKER_RUN_TRAEFIK_TEST),) ./script/make.sh generate binary test-integration | ||||
| 	$(if $(IN_DOCKER),$(DOCKER_RUN_TRAEFIK_TEST)) ./script/make.sh generate binary test-integration | ||||
|  | ||||
| ## Pull all images for integration tests | ||||
| .PHONY: pull-images | ||||
| @@ -190,7 +189,7 @@ generate-genconf: | ||||
| .PHONY: release-packages | ||||
| release-packages: generate-webui build-dev-image | ||||
| 	rm -rf dist | ||||
| 	$(if $(IN_DOCKER),$(DOCKER_RUN_TRAEFIK_NOTTY)) goreleaser release --skip-publish --timeout="90m" | ||||
| 	$(if $(IN_DOCKER),$(DOCKER_RUN_TRAEFIK_NOTTY)) goreleaser release --skip-publish -p 2 --timeout="90m" | ||||
| 	$(if $(IN_DOCKER),$(DOCKER_RUN_TRAEFIK_NOTTY)) tar cfz dist/traefik-${VERSION}.src.tar.gz \ | ||||
| 		--exclude-vcs \ | ||||
| 		--exclude .idea \ | ||||
|   | ||||
							
								
								
									
										18
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,6 +1,10 @@ | ||||
|  | ||||
| <p align="center"> | ||||
| <img src="docs/content/assets/img/traefik.logo.png" alt="Traefik" title="Traefik" /> | ||||
|     <picture> | ||||
|       <source media="(prefers-color-scheme: dark)" srcset="docs/content/assets/img/traefik.logo-dark.png"> | ||||
|       <source media="(prefers-color-scheme: light)" srcset="docs/content/assets/img/traefik.logo.png"> | ||||
|       <img alt="Traefik" title="Traefik" src="docs/content/assets/img/traefik.logo.png"> | ||||
|     </picture> | ||||
| </p> | ||||
|  | ||||
| [](https://semaphoreci.com/containous/traefik) | ||||
| @@ -10,9 +14,8 @@ | ||||
| [](https://community.traefik.io/) | ||||
| [](https://twitter.com/intent/follow?screen_name=traefik) | ||||
|  | ||||
|  | ||||
| Traefik (pronounced _traffic_) is a modern HTTP reverse proxy and load balancer that makes deploying microservices easy. | ||||
| Traefik integrates with your existing infrastructure components ([Docker](https://www.docker.com/), [Swarm mode](https://docs.docker.com/engine/swarm/), [Kubernetes](https://kubernetes.io), [Marathon](https://mesosphere.github.io/marathon/), [Consul](https://www.consul.io/), [Etcd](https://coreos.com/etcd/), [Rancher](https://rancher.com), [Amazon ECS](https://aws.amazon.com/ecs), ...) and configures itself automatically and dynamically. | ||||
| Traefik integrates with your existing infrastructure components ([Docker](https://www.docker.com/), [Swarm mode](https://docs.docker.com/engine/swarm/), [Kubernetes](https://kubernetes.io), [Consul](https://www.consul.io/), [Etcd](https://coreos.com/etcd/), [Rancher v2](https://rancher.com), [Amazon ECS](https://aws.amazon.com/ecs), ...) and configures itself automatically and dynamically. | ||||
| Pointing Traefik at your orchestrator should be the _only_ configuration step you need. | ||||
|  | ||||
| --- | ||||
| @@ -58,20 +61,17 @@ _(But if you'd rather configure some of your routes manually, Traefik supports t | ||||
| - Provides HTTPS to your microservices by leveraging [Let's Encrypt](https://letsencrypt.org)  (wildcard certificates support) | ||||
| - Circuit breakers, retry | ||||
| - See the magic through its clean web UI | ||||
| - Websocket, HTTP/2, GRPC ready | ||||
| - Provides metrics (Rest, Prometheus, Datadog, Statsd, InfluxDB) | ||||
| - Websocket, HTTP/2, gRPC ready | ||||
| - Provides metrics (Rest, Prometheus, Datadog, Statsd, InfluxDB 2.X) | ||||
| - Keeps access logs (JSON, CLF) | ||||
| - Fast | ||||
| - Exposes a Rest API | ||||
| - Packaged as a single binary file (made with :heart: with go) and available as an [official](https://hub.docker.com/r/_/traefik/) docker image | ||||
|  | ||||
|  | ||||
| ## Supported Backends | ||||
|  | ||||
| - [Docker](https://doc.traefik.io/traefik/providers/docker/) / [Swarm mode](https://doc.traefik.io/traefik/providers/docker/) | ||||
| - [Kubernetes](https://doc.traefik.io/traefik/providers/kubernetes-crd/) | ||||
| - [Marathon](https://doc.traefik.io/traefik/providers/marathon/) | ||||
| - [Rancher](https://doc.traefik.io/traefik/providers/rancher/) (Metadata) | ||||
| - [File](https://doc.traefik.io/traefik/providers/file/) | ||||
|  | ||||
| ## Quickstart | ||||
| @@ -93,6 +93,7 @@ A collection of contributions around Traefik can be found at [https://awesome.tr | ||||
| ## Support | ||||
|  | ||||
| To get community support, you can: | ||||
|  | ||||
| - join the Traefik community forum: [](https://community.traefik.io/) | ||||
|  | ||||
| If you need commercial support, please contact [Traefik.io](https://traefik.io) by mail: <mailto:support@traefik.io>. | ||||
| @@ -127,7 +128,6 @@ We are strongly promoting a philosophy of openness and sharing, and firmly stand | ||||
| This [document](docs/content/contributing/maintainers-guidelines.md) describes how to be part of the core team as well as various responsibilities and guidelines for Traefik maintainers. | ||||
| You can also find more information on our process to review pull requests and manage issues [in this document](docs/content/contributing/maintainers.md). | ||||
|  | ||||
|  | ||||
| ## Contributing | ||||
|  | ||||
| If you'd like to contribute to the project, refer to the [contributing documentation](CONTRIBUTING.md). | ||||
|   | ||||
| @@ -1,7 +1,6 @@ | ||||
| # Security Policy | ||||
|  | ||||
| We strongly advise you to register your Traefik instances to [Pilot](https://pilot.traefik.io) to be notified of security advisories that apply to your Traefik version. | ||||
| You can also join our security mailing list to be aware of the latest announcements from our security team. | ||||
| You can join our security mailing list to be aware of the latest announcements from our security team. | ||||
| You can subscribe sending a mail to security+subscribe@traefik.io or on [the online viewer](https://groups.google.com/a/traefik.io/forum/#!forum/security). | ||||
|  | ||||
| Reported vulnerabilities can be found on [cve.mitre.org](https://cve.mitre.org/cgi-bin/cvekey.cgi?keyword=traefik). | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| FROM golang:1.17-alpine | ||||
| FROM golang:1.20-alpine | ||||
|  | ||||
| RUN apk --no-cache --no-progress add git mercurial bash gcc musl-dev curl tar ca-certificates tzdata \ | ||||
|     && update-ca-certificates \ | ||||
| @@ -13,10 +13,10 @@ RUN mkdir -p /usr/local/bin \ | ||||
|     | tar -xzC /usr/local/bin --transform 's#^.+/##x' | ||||
|  | ||||
| # Download golangci-lint binary to bin folder in $GOPATH | ||||
| RUN curl -sfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | bash -s -- -b $GOPATH/bin v1.46.2 | ||||
| RUN curl -sfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | bash -s -- -b $GOPATH/bin v1.52.2 | ||||
|  | ||||
| # Download misspell binary to bin folder in $GOPATH | ||||
| RUN curl -sfL https://raw.githubusercontent.com/client9/misspell/master/install-misspell.sh | bash -s -- -b $GOPATH/bin v0.3.4 | ||||
| RUN curl -sfL https://raw.githubusercontent.com/golangci/misspell/master/install-misspell.sh | bash -s -- -b $GOPATH/bin v0.4.0 | ||||
|  | ||||
| # Download goreleaser binary to bin folder in $GOPATH | ||||
| RUN curl -sfL https://gist.githubusercontent.com/traefiker/6d7ac019c11d011e4f131bb2cca8900e/raw/goreleaser.sh | sh | ||||
|   | ||||
| @@ -4,7 +4,7 @@ import ( | ||||
| 	"time" | ||||
|  | ||||
| 	ptypes "github.com/traefik/paerser/types" | ||||
| 	"github.com/traefik/traefik/v2/pkg/config/static" | ||||
| 	"github.com/traefik/traefik/v3/pkg/config/static" | ||||
| ) | ||||
|  | ||||
| // TraefikCmdConfiguration wraps the static configuration and extra parameters. | ||||
| @@ -28,6 +28,10 @@ func NewTraefikConfiguration() *TraefikCmdConfiguration { | ||||
| 			ServersTransport: &static.ServersTransport{ | ||||
| 				MaxIdleConnsPerHost: 200, | ||||
| 			}, | ||||
| 			TCPServersTransport: &static.TCPServersTransport{ | ||||
| 				DialTimeout:   ptypes.Duration(30 * time.Second), | ||||
| 				DialKeepAlive: ptypes.Duration(15 * time.Second), | ||||
| 			}, | ||||
| 		}, | ||||
| 		ConfigFile: "", | ||||
| 	} | ||||
|   | ||||
| @@ -8,7 +8,7 @@ import ( | ||||
| 	"time" | ||||
|  | ||||
| 	"github.com/traefik/paerser/cli" | ||||
| 	"github.com/traefik/traefik/v2/pkg/config/static" | ||||
| 	"github.com/traefik/traefik/v3/pkg/config/static" | ||||
| ) | ||||
|  | ||||
| // NewCmd builds a new HealthCheck command. | ||||
| @@ -64,7 +64,7 @@ func Do(staticConfiguration static.Configuration) (*http.Response, error) { | ||||
| 	client := &http.Client{Timeout: 5 * time.Second} | ||||
| 	protocol := "http" | ||||
|  | ||||
| 	// FIXME Handle TLS on ping etc... | ||||
| 	// TODO Handle TLS on ping etc... | ||||
| 	// if pingEntryPoint.TLS != nil { | ||||
| 	// 	protocol = "https" | ||||
| 	// 	tr := &http.Transport{ | ||||
|   | ||||
| @@ -72,22 +72,16 @@ func NewCentrifuge(rootPkg string) (*Centrifuge, error) { | ||||
|  | ||||
| // Run runs the code extraction and the code generation. | ||||
| func (c Centrifuge) Run(dest string, pkgName string) error { | ||||
| 	files, err := c.run(c.pkg.Scope(), c.rootPkg, pkgName) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	files := c.run(c.pkg.Scope(), c.rootPkg, pkgName) | ||||
|  | ||||
| 	err = fileWriter{baseDir: dest}.Write(files) | ||||
| 	err := fileWriter{baseDir: dest}.Write(files) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	for _, p := range c.pkg.Imports() { | ||||
| 		if contains(c.IncludedImports, p.Path()) { | ||||
| 			fls, err := c.run(p.Scope(), p.Path(), p.Name()) | ||||
| 			if err != nil { | ||||
| 				return err | ||||
| 			} | ||||
| 			fls := c.run(p.Scope(), p.Path(), p.Name()) | ||||
|  | ||||
| 			err = fileWriter{baseDir: filepath.Join(dest, p.Name())}.Write(fls) | ||||
| 			if err != nil { | ||||
| @@ -99,7 +93,7 @@ func (c Centrifuge) Run(dest string, pkgName string) error { | ||||
| 	return err | ||||
| } | ||||
|  | ||||
| func (c Centrifuge) run(sc *types.Scope, rootPkg string, pkgName string) (map[string]*File, error) { | ||||
| func (c Centrifuge) run(sc *types.Scope, rootPkg string, pkgName string) map[string]*File { | ||||
| 	files := map[string]*File{} | ||||
|  | ||||
| 	for _, name := range sc.Names() { | ||||
| @@ -158,7 +152,7 @@ func (c Centrifuge) run(sc *types.Scope, rootPkg string, pkgName string) (map[st | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return files, nil | ||||
| 	return files | ||||
| } | ||||
|  | ||||
| func (c Centrifuge) writeStruct(name string, obj *types.Struct, rootPkg string, elt *File) string { | ||||
|   | ||||
| @@ -11,7 +11,7 @@ import ( | ||||
| 	"strings" | ||||
| ) | ||||
|  | ||||
| const rootPkg = "github.com/traefik/traefik/v2/pkg/config/dynamic" | ||||
| const rootPkg = "github.com/traefik/traefik/v3/pkg/config/dynamic" | ||||
|  | ||||
| const ( | ||||
| 	destModuleName = "github.com/traefik/genconf" | ||||
| @@ -57,8 +57,8 @@ func run(dest string) error { | ||||
| 	} | ||||
|  | ||||
| 	centrifuge.IncludedImports = []string{ | ||||
| 		"github.com/traefik/traefik/v2/pkg/tls", | ||||
| 		"github.com/traefik/traefik/v2/pkg/types", | ||||
| 		"github.com/traefik/traefik/v3/pkg/tls", | ||||
| 		"github.com/traefik/traefik/v3/pkg/types", | ||||
| 	} | ||||
|  | ||||
| 	centrifuge.ExcludedTypes = []string{ | ||||
| @@ -71,8 +71,8 @@ func run(dest string) error { | ||||
| 	} | ||||
|  | ||||
| 	centrifuge.ExcludedFiles = []string{ | ||||
| 		"github.com/traefik/traefik/v2/pkg/types/logs.go", | ||||
| 		"github.com/traefik/traefik/v2/pkg/types/metrics.go", | ||||
| 		"github.com/traefik/traefik/v3/pkg/types/logs.go", | ||||
| 		"github.com/traefik/traefik/v3/pkg/types/metrics.go", | ||||
| 	} | ||||
|  | ||||
| 	centrifuge.TypeCleaner = cleanType | ||||
| @@ -87,11 +87,11 @@ func run(dest string) error { | ||||
| } | ||||
|  | ||||
| func cleanType(typ types.Type, base string) string { | ||||
| 	if typ.String() == "github.com/traefik/traefik/v2/pkg/tls.FileOrContent" { | ||||
| 	if typ.String() == "github.com/traefik/traefik/v3/pkg/tls.FileOrContent" { | ||||
| 		return "string" | ||||
| 	} | ||||
|  | ||||
| 	if typ.String() == "[]github.com/traefik/traefik/v2/pkg/tls.FileOrContent" { | ||||
| 	if typ.String() == "[]github.com/traefik/traefik/v3/pkg/tls.FileOrContent" { | ||||
| 		return "[]string" | ||||
| 	} | ||||
|  | ||||
| @@ -103,8 +103,8 @@ func cleanType(typ types.Type, base string) string { | ||||
| 		return strings.ReplaceAll(typ.String(), base+".", "") | ||||
| 	} | ||||
|  | ||||
| 	if strings.Contains(typ.String(), "github.com/traefik/traefik/v2/pkg/") { | ||||
| 		return strings.ReplaceAll(typ.String(), "github.com/traefik/traefik/v2/pkg/", "") | ||||
| 	if strings.Contains(typ.String(), "github.com/traefik/traefik/v3/pkg/") { | ||||
| 		return strings.ReplaceAll(typ.String(), "github.com/traefik/traefik/v3/pkg/", "") | ||||
| 	} | ||||
|  | ||||
| 	return typ.String() | ||||
| @@ -114,9 +114,9 @@ func cleanPackage(src string) string { | ||||
| 	switch src { | ||||
| 	case "github.com/traefik/paerser/types": | ||||
| 		return "" | ||||
| 	case "github.com/traefik/traefik/v2/pkg/tls": | ||||
| 	case "github.com/traefik/traefik/v3/pkg/tls": | ||||
| 		return path.Join(destModuleName, destPkg, "tls") | ||||
| 	case "github.com/traefik/traefik/v2/pkg/types": | ||||
| 	case "github.com/traefik/traefik/v3/pkg/types": | ||||
| 		return path.Join(destModuleName, destPkg, "types") | ||||
| 	default: | ||||
| 		return src | ||||
|   | ||||
							
								
								
									
										89
									
								
								cmd/traefik/logger.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								cmd/traefik/logger.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,89 @@ | ||||
| package main | ||||
|  | ||||
| import ( | ||||
| 	"io" | ||||
| 	stdlog "log" | ||||
| 	"os" | ||||
| 	"strings" | ||||
| 	"time" | ||||
|  | ||||
| 	"github.com/natefinch/lumberjack" | ||||
| 	"github.com/rs/zerolog" | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/traefik/traefik/v3/pkg/config/static" | ||||
| 	"github.com/traefik/traefik/v3/pkg/logs" | ||||
| ) | ||||
|  | ||||
| func init() { | ||||
| 	// hide the first logs before the setup of the logger. | ||||
| 	zerolog.SetGlobalLevel(zerolog.ErrorLevel) | ||||
| } | ||||
|  | ||||
| func setupLogger(staticConfiguration *static.Configuration) { | ||||
| 	// configure log format | ||||
| 	w := getLogWriter(staticConfiguration) | ||||
|  | ||||
| 	// configure log level | ||||
| 	logLevel := getLogLevel(staticConfiguration) | ||||
|  | ||||
| 	// create logger | ||||
| 	logCtx := zerolog.New(w).With().Timestamp() | ||||
| 	if logLevel <= zerolog.DebugLevel { | ||||
| 		logCtx = logCtx.Caller() | ||||
| 	} | ||||
|  | ||||
| 	log.Logger = logCtx.Logger().Level(logLevel) | ||||
| 	zerolog.DefaultContextLogger = &log.Logger | ||||
| 	zerolog.SetGlobalLevel(logLevel) | ||||
|  | ||||
| 	// Global logrus replacement (related to lib like go-rancher-metadata, docker, etc.) | ||||
| 	logrus.StandardLogger().Out = logs.NoLevel(log.Logger, zerolog.DebugLevel) | ||||
|  | ||||
| 	// configure default standard log. | ||||
| 	stdlog.SetFlags(stdlog.Lshortfile | stdlog.LstdFlags) | ||||
| 	stdlog.SetOutput(logs.NoLevel(log.Logger, zerolog.DebugLevel)) | ||||
| } | ||||
|  | ||||
| func getLogWriter(staticConfiguration *static.Configuration) io.Writer { | ||||
| 	var w io.Writer = os.Stderr | ||||
|  | ||||
| 	if staticConfiguration.Log != nil && len(staticConfiguration.Log.FilePath) > 0 { | ||||
| 		_, _ = os.Create(staticConfiguration.Log.FilePath) | ||||
| 		w = &lumberjack.Logger{ | ||||
| 			Filename:   staticConfiguration.Log.FilePath, | ||||
| 			MaxSize:    staticConfiguration.Log.MaxSize, | ||||
| 			MaxBackups: staticConfiguration.Log.MaxBackups, | ||||
| 			MaxAge:     staticConfiguration.Log.MaxAge, | ||||
| 			Compress:   true, | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if staticConfiguration.Log == nil || staticConfiguration.Log.Format != "json" { | ||||
| 		w = zerolog.ConsoleWriter{ | ||||
| 			Out:        w, | ||||
| 			TimeFormat: time.RFC3339, | ||||
| 			NoColor:    staticConfiguration.Log != nil && (staticConfiguration.Log.NoColor || len(staticConfiguration.Log.FilePath) > 0), | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return w | ||||
| } | ||||
|  | ||||
| func getLogLevel(staticConfiguration *static.Configuration) zerolog.Level { | ||||
| 	levelStr := "error" | ||||
| 	if staticConfiguration.Log != nil && staticConfiguration.Log.Level != "" { | ||||
| 		levelStr = strings.ToLower(staticConfiguration.Log.Level) | ||||
| 	} | ||||
|  | ||||
| 	logLevel, err := zerolog.ParseLevel(strings.ToLower(levelStr)) | ||||
| 	if err != nil { | ||||
| 		log.Error().Err(err). | ||||
| 			Str("logLevel", levelStr). | ||||
| 			Msg("Unspecified or invalid log level, setting the level to default (ERROR)...") | ||||
|  | ||||
| 		logLevel = zerolog.ErrorLevel | ||||
| 	} | ||||
|  | ||||
| 	return logLevel | ||||
| } | ||||
| @@ -3,8 +3,8 @@ package main | ||||
| import ( | ||||
| 	"fmt" | ||||
|  | ||||
| 	"github.com/traefik/traefik/v2/pkg/config/static" | ||||
| 	"github.com/traefik/traefik/v2/pkg/plugins" | ||||
| 	"github.com/traefik/traefik/v3/pkg/config/static" | ||||
| 	"github.com/traefik/traefik/v3/pkg/plugins" | ||||
| ) | ||||
|  | ||||
| const outputDir = "./plugins-storage/" | ||||
| @@ -27,21 +27,20 @@ func initPlugins(staticCfg *static.Configuration) (*plugins.Client, map[string]p | ||||
| 	var client *plugins.Client | ||||
| 	plgs := map[string]plugins.Descriptor{} | ||||
|  | ||||
| 	if isPilotEnabled(staticCfg) && hasPlugins(staticCfg) { | ||||
| 	if hasPlugins(staticCfg) { | ||||
| 		opts := plugins.ClientOptions{ | ||||
| 			Output: outputDir, | ||||
| 			Token:  staticCfg.Pilot.Token, | ||||
| 		} | ||||
|  | ||||
| 		var err error | ||||
| 		client, err = plugins.NewClient(opts) | ||||
| 		if err != nil { | ||||
| 			return nil, nil, nil, err | ||||
| 			return nil, nil, nil, fmt.Errorf("unable to create plugins client: %w", err) | ||||
| 		} | ||||
|  | ||||
| 		err = plugins.SetupRemotePlugins(client, staticCfg.Experimental.Plugins) | ||||
| 		if err != nil { | ||||
| 			return nil, nil, nil, err | ||||
| 			return nil, nil, nil, fmt.Errorf("unable to set up plugins environment: %w", err) | ||||
| 		} | ||||
|  | ||||
| 		plgs = staticCfg.Experimental.Plugins | ||||
| @@ -75,10 +74,6 @@ func checkUniquePluginNames(e *static.Experimental) error { | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| func isPilotEnabled(staticCfg *static.Configuration) bool { | ||||
| 	return staticCfg.Pilot != nil && staticCfg.Pilot.Token != "" | ||||
| } | ||||
|  | ||||
| func hasPlugins(staticCfg *static.Configuration) bool { | ||||
| 	return staticCfg.Experimental != nil && len(staticCfg.Experimental.Plugins) > 0 | ||||
| } | ||||
|   | ||||
| @@ -9,7 +9,6 @@ import ( | ||||
| 	"net/http" | ||||
| 	"os" | ||||
| 	"os/signal" | ||||
| 	"path/filepath" | ||||
| 	"sort" | ||||
| 	"strings" | ||||
| 	"syscall" | ||||
| @@ -18,31 +17,35 @@ import ( | ||||
| 	"github.com/coreos/go-systemd/daemon" | ||||
| 	"github.com/go-acme/lego/v4/challenge" | ||||
| 	gokitmetrics "github.com/go-kit/kit/metrics" | ||||
| 	"github.com/rs/zerolog/log" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/spiffe/go-spiffe/v2/workloadapi" | ||||
| 	"github.com/traefik/paerser/cli" | ||||
| 	"github.com/traefik/traefik/v2/cmd" | ||||
| 	"github.com/traefik/traefik/v2/cmd/healthcheck" | ||||
| 	cmdVersion "github.com/traefik/traefik/v2/cmd/version" | ||||
| 	tcli "github.com/traefik/traefik/v2/pkg/cli" | ||||
| 	"github.com/traefik/traefik/v2/pkg/collector" | ||||
| 	"github.com/traefik/traefik/v2/pkg/config/dynamic" | ||||
| 	"github.com/traefik/traefik/v2/pkg/config/runtime" | ||||
| 	"github.com/traefik/traefik/v2/pkg/config/static" | ||||
| 	"github.com/traefik/traefik/v2/pkg/log" | ||||
| 	"github.com/traefik/traefik/v2/pkg/metrics" | ||||
| 	"github.com/traefik/traefik/v2/pkg/middlewares/accesslog" | ||||
| 	"github.com/traefik/traefik/v2/pkg/pilot" | ||||
| 	"github.com/traefik/traefik/v2/pkg/provider/acme" | ||||
| 	"github.com/traefik/traefik/v2/pkg/provider/aggregator" | ||||
| 	"github.com/traefik/traefik/v2/pkg/provider/traefik" | ||||
| 	"github.com/traefik/traefik/v2/pkg/safe" | ||||
| 	"github.com/traefik/traefik/v2/pkg/server" | ||||
| 	"github.com/traefik/traefik/v2/pkg/server/middleware" | ||||
| 	"github.com/traefik/traefik/v2/pkg/server/service" | ||||
| 	traefiktls "github.com/traefik/traefik/v2/pkg/tls" | ||||
| 	"github.com/traefik/traefik/v2/pkg/types" | ||||
| 	"github.com/traefik/traefik/v2/pkg/version" | ||||
| 	"github.com/vulcand/oxy/roundrobin" | ||||
| 	"github.com/traefik/traefik/v3/cmd" | ||||
| 	"github.com/traefik/traefik/v3/cmd/healthcheck" | ||||
| 	cmdVersion "github.com/traefik/traefik/v3/cmd/version" | ||||
| 	tcli "github.com/traefik/traefik/v3/pkg/cli" | ||||
| 	"github.com/traefik/traefik/v3/pkg/collector" | ||||
| 	"github.com/traefik/traefik/v3/pkg/config/dynamic" | ||||
| 	"github.com/traefik/traefik/v3/pkg/config/runtime" | ||||
| 	"github.com/traefik/traefik/v3/pkg/config/static" | ||||
| 	"github.com/traefik/traefik/v3/pkg/logs" | ||||
| 	"github.com/traefik/traefik/v3/pkg/metrics" | ||||
| 	"github.com/traefik/traefik/v3/pkg/middlewares/accesslog" | ||||
| 	"github.com/traefik/traefik/v3/pkg/provider/acme" | ||||
| 	"github.com/traefik/traefik/v3/pkg/provider/aggregator" | ||||
| 	"github.com/traefik/traefik/v3/pkg/provider/tailscale" | ||||
| 	"github.com/traefik/traefik/v3/pkg/provider/traefik" | ||||
| 	"github.com/traefik/traefik/v3/pkg/safe" | ||||
| 	"github.com/traefik/traefik/v3/pkg/server" | ||||
| 	"github.com/traefik/traefik/v3/pkg/server/middleware" | ||||
| 	"github.com/traefik/traefik/v3/pkg/server/service" | ||||
| 	"github.com/traefik/traefik/v3/pkg/tcp" | ||||
| 	traefiktls "github.com/traefik/traefik/v3/pkg/tls" | ||||
| 	"github.com/traefik/traefik/v3/pkg/tracing" | ||||
| 	"github.com/traefik/traefik/v3/pkg/tracing/jaeger" | ||||
| 	"github.com/traefik/traefik/v3/pkg/types" | ||||
| 	"github.com/traefik/traefik/v3/pkg/version" | ||||
| ) | ||||
|  | ||||
| func main() { | ||||
| @@ -76,7 +79,7 @@ Complete documentation is available at https://traefik.io`, | ||||
|  | ||||
| 	err = cli.Execute(cmdTraefik) | ||||
| 	if err != nil { | ||||
| 		stdlog.Println(err) | ||||
| 		log.Error().Err(err).Msg("Command error") | ||||
| 		logrus.Exit(1) | ||||
| 	} | ||||
|  | ||||
| @@ -84,27 +87,24 @@ Complete documentation is available at https://traefik.io`, | ||||
| } | ||||
|  | ||||
| func runCmd(staticConfiguration *static.Configuration) error { | ||||
| 	configureLogging(staticConfiguration) | ||||
| 	setupLogger(staticConfiguration) | ||||
|  | ||||
| 	http.DefaultTransport.(*http.Transport).Proxy = http.ProxyFromEnvironment | ||||
|  | ||||
| 	if err := roundrobin.SetDefaultWeight(0); err != nil { | ||||
| 		log.WithoutContext().Errorf("Could not set round robin default weight: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	staticConfiguration.SetEffectiveConfiguration() | ||||
| 	if err := staticConfiguration.ValidateConfiguration(); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	log.WithoutContext().Infof("Traefik version %s built on %s", version.Version, version.BuildDate) | ||||
| 	log.Info().Str("version", version.Version). | ||||
| 		Msgf("Traefik version %s built on %s", version.Version, version.BuildDate) | ||||
|  | ||||
| 	jsonConf, err := json.Marshal(staticConfiguration) | ||||
| 	if err != nil { | ||||
| 		log.WithoutContext().Errorf("Could not marshal static configuration: %v", err) | ||||
| 		log.WithoutContext().Debugf("Static configuration loaded [struct] %#v", staticConfiguration) | ||||
| 		log.Error().Err(err).Msg("Could not marshal static configuration") | ||||
| 		log.Debug().Interface("staticConfiguration", staticConfiguration).Msg("Static configuration loaded [struct]") | ||||
| 	} else { | ||||
| 		log.WithoutContext().Debugf("Static configuration loaded %s", string(jsonConf)) | ||||
| 		log.Debug().RawJSON("staticConfiguration", jsonConf).Msg("Static configuration loaded [json]") | ||||
| 	} | ||||
|  | ||||
| 	if staticConfiguration.Global.CheckNewVersion { | ||||
| @@ -129,16 +129,16 @@ func runCmd(staticConfiguration *static.Configuration) error { | ||||
|  | ||||
| 	sent, err := daemon.SdNotify(false, "READY=1") | ||||
| 	if !sent && err != nil { | ||||
| 		log.WithoutContext().Errorf("Failed to notify: %v", err) | ||||
| 		log.Error().Err(err).Msg("Failed to notify") | ||||
| 	} | ||||
|  | ||||
| 	t, err := daemon.SdWatchdogEnabled(false) | ||||
| 	if err != nil { | ||||
| 		log.WithoutContext().Errorf("Could not enable Watchdog: %v", err) | ||||
| 		log.Error().Err(err).Msg("Could not enable Watchdog") | ||||
| 	} else if t != 0 { | ||||
| 		// Send a ping each half time given | ||||
| 		t /= 2 | ||||
| 		log.WithoutContext().Infof("Watchdog activated with timer duration %s", t) | ||||
| 		log.Info().Msgf("Watchdog activated with timer duration %s", t) | ||||
| 		safe.Go(func() { | ||||
| 			tick := time.Tick(t) | ||||
| 			for range tick { | ||||
| @@ -149,17 +149,17 @@ func runCmd(staticConfiguration *static.Configuration) error { | ||||
|  | ||||
| 				if staticConfiguration.Ping == nil || errHealthCheck == nil { | ||||
| 					if ok, _ := daemon.SdNotify(false, "WATCHDOG=1"); !ok { | ||||
| 						log.WithoutContext().Error("Fail to tick watchdog") | ||||
| 						log.Error().Msg("Fail to tick watchdog") | ||||
| 					} | ||||
| 				} else { | ||||
| 					log.WithoutContext().Error(errHealthCheck) | ||||
| 					log.Error().Err(errHealthCheck).Send() | ||||
| 				} | ||||
| 			} | ||||
| 		}) | ||||
| 	} | ||||
|  | ||||
| 	svr.Wait() | ||||
| 	log.WithoutContext().Info("Shutting down") | ||||
| 	log.Info().Msg("Shutting down") | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| @@ -180,8 +180,7 @@ func setupServer(staticConfiguration *static.Configuration) (*server.Server, err | ||||
| 	tlsManager := traefiktls.NewManager() | ||||
| 	httpChallengeProvider := acme.NewChallengeHTTP() | ||||
|  | ||||
| 	// we need to wait at least 2 times the ProvidersThrottleDuration to be sure to handle the challenge. | ||||
| 	tlsChallengeProvider := acme.NewChallengeTLSALPN(time.Duration(staticConfiguration.Providers.ProvidersThrottleDuration) * 2) | ||||
| 	tlsChallengeProvider := acme.NewChallengeTLSALPN() | ||||
| 	err = providerAggregator.AddProvider(tlsChallengeProvider) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| @@ -189,9 +188,18 @@ func setupServer(staticConfiguration *static.Configuration) (*server.Server, err | ||||
|  | ||||
| 	acmeProviders := initACMEProvider(staticConfiguration, &providerAggregator, tlsManager, httpChallengeProvider, tlsChallengeProvider) | ||||
|  | ||||
| 	// Tailscale | ||||
|  | ||||
| 	tsProviders := initTailscaleProviders(staticConfiguration, &providerAggregator) | ||||
|  | ||||
| 	// Metrics | ||||
|  | ||||
| 	metricRegistries := registerMetricClients(staticConfiguration.Metrics) | ||||
| 	metricsRegistry := metrics.NewMultiRegistry(metricRegistries) | ||||
|  | ||||
| 	// Entrypoints | ||||
|  | ||||
| 	serverEntryPointsTCP, err := server.NewTCPEntryPoints(staticConfiguration.EntryPoints, staticConfiguration.HostResolver) | ||||
| 	serverEntryPointsTCP, err := server.NewTCPEntryPoints(staticConfiguration.EntryPoints, staticConfiguration.HostResolver, metricsRegistry) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| @@ -201,34 +209,20 @@ func setupServer(staticConfiguration *static.Configuration) (*server.Server, err | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	// Pilot | ||||
|  | ||||
| 	var aviator *pilot.Pilot | ||||
| 	var pilotRegistry *metrics.PilotRegistry | ||||
| 	if isPilotEnabled(staticConfiguration) { | ||||
| 		pilotRegistry = metrics.RegisterPilot() | ||||
|  | ||||
| 		aviator = pilot.New(staticConfiguration.Pilot.Token, pilotRegistry, routinesPool) | ||||
|  | ||||
| 		routinesPool.GoCtx(func(ctx context.Context) { | ||||
| 			aviator.Tick(ctx) | ||||
| 		}) | ||||
| 	} | ||||
|  | ||||
| 	if staticConfiguration.Pilot != nil { | ||||
| 		version.PilotEnabled = staticConfiguration.Pilot.Dashboard | ||||
| 	} | ||||
|  | ||||
| 	// Plugins | ||||
|  | ||||
| 	pluginBuilder, err := createPluginBuilder(staticConfiguration) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 		log.Error().Err(err).Msg("Plugins are disabled because an error has occurred.") | ||||
| 	} | ||||
|  | ||||
| 	// Providers plugins | ||||
|  | ||||
| 	for name, conf := range staticConfiguration.Providers.Plugin { | ||||
| 		if pluginBuilder == nil { | ||||
| 			break | ||||
| 		} | ||||
|  | ||||
| 		p, err := pluginBuilder.BuildProvider(name, conf) | ||||
| 		if err != nil { | ||||
| 			return nil, fmt.Errorf("plugin: failed to build provider: %w", err) | ||||
| @@ -240,32 +234,45 @@ func setupServer(staticConfiguration *static.Configuration) (*server.Server, err | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// Metrics | ||||
|  | ||||
| 	metricRegistries := registerMetricClients(staticConfiguration.Metrics) | ||||
| 	if pilotRegistry != nil { | ||||
| 		metricRegistries = append(metricRegistries, pilotRegistry) | ||||
| 	} | ||||
| 	metricsRegistry := metrics.NewMultiRegistry(metricRegistries) | ||||
|  | ||||
| 	// Service manager factory | ||||
|  | ||||
| 	roundTripperManager := service.NewRoundTripperManager() | ||||
| 	var spiffeX509Source *workloadapi.X509Source | ||||
| 	if staticConfiguration.Spiffe != nil && staticConfiguration.Spiffe.WorkloadAPIAddr != "" { | ||||
| 		log.Info().Str("workloadAPIAddr", staticConfiguration.Spiffe.WorkloadAPIAddr). | ||||
| 			Msg("Waiting on SPIFFE SVID delivery") | ||||
|  | ||||
| 		spiffeX509Source, err = workloadapi.NewX509Source( | ||||
| 			ctx, | ||||
| 			workloadapi.WithClientOptions( | ||||
| 				workloadapi.WithAddr( | ||||
| 					staticConfiguration.Spiffe.WorkloadAPIAddr, | ||||
| 				), | ||||
| 			), | ||||
| 		) | ||||
| 		if err != nil { | ||||
| 			return nil, fmt.Errorf("unable to create SPIFFE x509 source: %w", err) | ||||
| 		} | ||||
| 		log.Info().Msg("Successfully obtained SPIFFE SVID.") | ||||
| 	} | ||||
|  | ||||
| 	roundTripperManager := service.NewRoundTripperManager(spiffeX509Source) | ||||
| 	dialerManager := tcp.NewDialerManager(spiffeX509Source) | ||||
| 	acmeHTTPHandler := getHTTPChallengeHandler(acmeProviders, httpChallengeProvider) | ||||
| 	managerFactory := service.NewManagerFactory(*staticConfiguration, routinesPool, metricsRegistry, roundTripperManager, acmeHTTPHandler) | ||||
|  | ||||
| 	// Router factory | ||||
|  | ||||
| 	accessLog := setupAccessLog(staticConfiguration.AccessLog) | ||||
| 	chainBuilder := middleware.NewChainBuilder(*staticConfiguration, metricsRegistry, accessLog) | ||||
| 	routerFactory := server.NewRouterFactory(*staticConfiguration, managerFactory, tlsManager, chainBuilder, pluginBuilder, metricsRegistry) | ||||
| 	tracer := setupTracing(staticConfiguration.Tracing) | ||||
|  | ||||
| 	chainBuilder := middleware.NewChainBuilder(metricsRegistry, accessLog, tracer) | ||||
| 	routerFactory := server.NewRouterFactory(*staticConfiguration, managerFactory, tlsManager, chainBuilder, pluginBuilder, metricsRegistry, dialerManager) | ||||
|  | ||||
| 	// Watcher | ||||
|  | ||||
| 	watcher := server.NewConfigurationWatcher( | ||||
| 		routinesPool, | ||||
| 		providerAggregator, | ||||
| 		time.Duration(staticConfiguration.Providers.ProvidersThrottleDuration), | ||||
| 		getDefaultsEntrypoints(staticConfiguration), | ||||
| 		"internal", | ||||
| 	) | ||||
| @@ -276,7 +283,7 @@ func setupServer(staticConfiguration *static.Configuration) (*server.Server, err | ||||
| 		tlsManager.UpdateConfigs(ctx, conf.TLS.Stores, conf.TLS.Options, conf.TLS.Certificates) | ||||
|  | ||||
| 		gauge := metricsRegistry.TLSCertsNotAfterTimestampGauge() | ||||
| 		for _, certificate := range tlsManager.GetCertificates() { | ||||
| 		for _, certificate := range tlsManager.GetServerCertificates() { | ||||
| 			appendCertMetric(gauge, certificate) | ||||
| 		} | ||||
| 	}) | ||||
| @@ -290,13 +297,14 @@ func setupServer(staticConfiguration *static.Configuration) (*server.Server, err | ||||
| 	// Server Transports | ||||
| 	watcher.AddListener(func(conf dynamic.Configuration) { | ||||
| 		roundTripperManager.Update(conf.HTTP.ServersTransports) | ||||
| 		dialerManager.Update(conf.TCP.ServersTransports) | ||||
| 	}) | ||||
|  | ||||
| 	// Switch router | ||||
| 	watcher.AddListener(switchRouter(routerFactory, serverEntryPointsTCP, serverEntryPointsUDP, aviator)) | ||||
| 	watcher.AddListener(switchRouter(routerFactory, serverEntryPointsTCP, serverEntryPointsUDP)) | ||||
|  | ||||
| 	// Metrics | ||||
| 	if metricsRegistry.IsEpEnabled() || metricsRegistry.IsSvcEnabled() { | ||||
| 	if metricsRegistry.IsEpEnabled() || metricsRegistry.IsRouterEnabled() || metricsRegistry.IsSvcEnabled() { | ||||
| 		var eps []string | ||||
| 		for key := range serverEntryPointsTCP { | ||||
| 			eps = append(eps, key) | ||||
| @@ -309,13 +317,22 @@ func setupServer(staticConfiguration *static.Configuration) (*server.Server, err | ||||
| 	// TLS challenge | ||||
| 	watcher.AddListener(tlsChallengeProvider.ListenConfiguration) | ||||
|  | ||||
| 	// ACME | ||||
| 	// Certificate Resolvers | ||||
|  | ||||
| 	resolverNames := map[string]struct{}{} | ||||
|  | ||||
| 	// ACME | ||||
| 	for _, p := range acmeProviders { | ||||
| 		resolverNames[p.ResolverName] = struct{}{} | ||||
| 		watcher.AddListener(p.ListenConfiguration) | ||||
| 	} | ||||
|  | ||||
| 	// Tailscale | ||||
| 	for _, p := range tsProviders { | ||||
| 		resolverNames[p.ResolverName] = struct{}{} | ||||
| 		watcher.AddListener(p.HandleConfigUpdate) | ||||
| 	} | ||||
|  | ||||
| 	// Certificate resolver logs | ||||
| 	watcher.AddListener(func(config dynamic.Configuration) { | ||||
| 		for rtName, rt := range config.HTTP.Routers { | ||||
| @@ -324,7 +341,8 @@ func setupServer(staticConfiguration *static.Configuration) (*server.Server, err | ||||
| 			} | ||||
|  | ||||
| 			if _, ok := resolverNames[rt.TLS.CertResolver]; !ok { | ||||
| 				log.WithoutContext().Errorf("the router %s uses a non-existent resolver: %s", rtName, rt.TLS.CertResolver) | ||||
| 				log.Error().Err(err).Str(logs.RouterName, rtName).Str("certificateResolver", rt.TLS.CertResolver). | ||||
| 					Msg("Router uses a non-existent certificate resolver") | ||||
| 			} | ||||
| 		} | ||||
| 	}) | ||||
| @@ -345,11 +363,27 @@ func getHTTPChallengeHandler(acmeProviders []*acme.Provider, httpChallengeProvid | ||||
|  | ||||
| func getDefaultsEntrypoints(staticConfiguration *static.Configuration) []string { | ||||
| 	var defaultEntryPoints []string | ||||
|  | ||||
| 	// Determines if at least one EntryPoint is configured to be used by default. | ||||
| 	var hasDefinedDefaults bool | ||||
| 	for _, ep := range staticConfiguration.EntryPoints { | ||||
| 		if ep.AsDefault { | ||||
| 			hasDefinedDefaults = true | ||||
| 			break | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	for name, cfg := range staticConfiguration.EntryPoints { | ||||
| 		// By default all entrypoints are considered. | ||||
| 		// If at least one is flagged, then only flagged entrypoints are included. | ||||
| 		if hasDefinedDefaults && !cfg.AsDefault { | ||||
| 			continue | ||||
| 		} | ||||
|  | ||||
| 		protocol, err := cfg.GetProtocol() | ||||
| 		if err != nil { | ||||
| 			// Should never happen because Traefik should not start if protocol is invalid. | ||||
| 			log.WithoutContext().Errorf("Invalid protocol: %v", err) | ||||
| 			log.Error().Err(err).Msg("Invalid protocol") | ||||
| 		} | ||||
|  | ||||
| 		if protocol != "udp" && name != static.DefaultInternalEntryPointName { | ||||
| @@ -361,22 +395,18 @@ func getDefaultsEntrypoints(staticConfiguration *static.Configuration) []string | ||||
| 	return defaultEntryPoints | ||||
| } | ||||
|  | ||||
| func switchRouter(routerFactory *server.RouterFactory, serverEntryPointsTCP server.TCPEntryPoints, serverEntryPointsUDP server.UDPEntryPoints, aviator *pilot.Pilot) func(conf dynamic.Configuration) { | ||||
| func switchRouter(routerFactory *server.RouterFactory, serverEntryPointsTCP server.TCPEntryPoints, serverEntryPointsUDP server.UDPEntryPoints) func(conf dynamic.Configuration) { | ||||
| 	return func(conf dynamic.Configuration) { | ||||
| 		rtConf := runtime.NewConfig(conf) | ||||
|  | ||||
| 		routers, udpRouters := routerFactory.CreateRouters(rtConf) | ||||
|  | ||||
| 		if aviator != nil { | ||||
| 			aviator.SetDynamicConfiguration(conf) | ||||
| 		} | ||||
|  | ||||
| 		serverEntryPointsTCP.Switch(routers) | ||||
| 		serverEntryPointsUDP.Switch(udpRouters) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // initACMEProvider creates an acme provider from the ACME part of globalConfiguration. | ||||
| // initACMEProvider creates and registers acme.Provider instances corresponding to the configured ACME certificate resolvers. | ||||
| func initACMEProvider(c *static.Configuration, providerAggregator *aggregator.ProviderAggregator, tlsManager *traefiktls.Manager, httpChallengeProvider, tlsChallengeProvider challenge.Provider) []*acme.Provider { | ||||
| 	localStores := map[string]*acme.LocalStore{} | ||||
|  | ||||
| @@ -399,7 +429,7 @@ func initACMEProvider(c *static.Configuration, providerAggregator *aggregator.Pr | ||||
| 		} | ||||
|  | ||||
| 		if err := providerAggregator.AddProvider(p); err != nil { | ||||
| 			log.WithoutContext().Errorf("The ACME resolver %q is skipped from the resolvers list because: %v", name, err) | ||||
| 			log.Error().Err(err).Str("resolver", name).Msg("The ACME resolve is skipped from the resolvers list") | ||||
| 			continue | ||||
| 		} | ||||
|  | ||||
| @@ -413,6 +443,27 @@ func initACMEProvider(c *static.Configuration, providerAggregator *aggregator.Pr | ||||
| 	return resolvers | ||||
| } | ||||
|  | ||||
| // initTailscaleProviders creates and registers tailscale.Provider instances corresponding to the configured Tailscale certificate resolvers. | ||||
| func initTailscaleProviders(cfg *static.Configuration, providerAggregator *aggregator.ProviderAggregator) []*tailscale.Provider { | ||||
| 	var providers []*tailscale.Provider | ||||
| 	for name, resolver := range cfg.CertificatesResolvers { | ||||
| 		if resolver.Tailscale == nil { | ||||
| 			continue | ||||
| 		} | ||||
|  | ||||
| 		tsProvider := &tailscale.Provider{ResolverName: name} | ||||
|  | ||||
| 		if err := providerAggregator.AddProvider(tsProvider); err != nil { | ||||
| 			log.Error().Err(err).Str(logs.ProviderName, name).Msg("Unable to create Tailscale provider") | ||||
| 			continue | ||||
| 		} | ||||
|  | ||||
| 		providers = append(providers, tsProvider) | ||||
| 	} | ||||
|  | ||||
| 	return providers | ||||
| } | ||||
|  | ||||
| func registerMetricClients(metricsConfig *types.Metrics) []metrics.Registry { | ||||
| 	if metricsConfig == nil { | ||||
| 		return nil | ||||
| @@ -421,33 +472,61 @@ func registerMetricClients(metricsConfig *types.Metrics) []metrics.Registry { | ||||
| 	var registries []metrics.Registry | ||||
|  | ||||
| 	if metricsConfig.Prometheus != nil { | ||||
| 		ctx := log.With(context.Background(), log.Str(log.MetricsProviderName, "prometheus")) | ||||
| 		prometheusRegister := metrics.RegisterPrometheus(ctx, metricsConfig.Prometheus) | ||||
| 		logger := log.With().Str(logs.MetricsProviderName, "prometheus").Logger() | ||||
|  | ||||
| 		prometheusRegister := metrics.RegisterPrometheus(logger.WithContext(context.Background()), metricsConfig.Prometheus) | ||||
| 		if prometheusRegister != nil { | ||||
| 			registries = append(registries, prometheusRegister) | ||||
| 			log.FromContext(ctx).Debug("Configured Prometheus metrics") | ||||
| 			logger.Debug().Msg("Configured Prometheus metrics") | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if metricsConfig.Datadog != nil { | ||||
| 		ctx := log.With(context.Background(), log.Str(log.MetricsProviderName, "datadog")) | ||||
| 		registries = append(registries, metrics.RegisterDatadog(ctx, metricsConfig.Datadog)) | ||||
| 		log.FromContext(ctx).Debugf("Configured Datadog metrics: pushing to %s once every %s", | ||||
| 			metricsConfig.Datadog.Address, metricsConfig.Datadog.PushInterval) | ||||
| 		logger := log.With().Str(logs.MetricsProviderName, "datadog").Logger() | ||||
|  | ||||
| 		registries = append(registries, metrics.RegisterDatadog(logger.WithContext(context.Background()), metricsConfig.Datadog)) | ||||
| 		logger.Debug(). | ||||
| 			Str("address", metricsConfig.Datadog.Address). | ||||
| 			Str("pushInterval", metricsConfig.Datadog.PushInterval.String()). | ||||
| 			Msgf("Configured Datadog metrics") | ||||
| 	} | ||||
|  | ||||
| 	if metricsConfig.StatsD != nil { | ||||
| 		ctx := log.With(context.Background(), log.Str(log.MetricsProviderName, "statsd")) | ||||
| 		registries = append(registries, metrics.RegisterStatsd(ctx, metricsConfig.StatsD)) | ||||
| 		log.FromContext(ctx).Debugf("Configured StatsD metrics: pushing to %s once every %s", | ||||
| 			metricsConfig.StatsD.Address, metricsConfig.StatsD.PushInterval) | ||||
| 		logger := log.With().Str(logs.MetricsProviderName, "statsd").Logger() | ||||
|  | ||||
| 		registries = append(registries, metrics.RegisterStatsd(logger.WithContext(context.Background()), metricsConfig.StatsD)) | ||||
| 		logger.Debug(). | ||||
| 			Str("address", metricsConfig.StatsD.Address). | ||||
| 			Str("pushInterval", metricsConfig.StatsD.PushInterval.String()). | ||||
| 			Msg("Configured StatsD metrics") | ||||
| 	} | ||||
|  | ||||
| 	if metricsConfig.InfluxDB != nil { | ||||
| 		ctx := log.With(context.Background(), log.Str(log.MetricsProviderName, "influxdb")) | ||||
| 		registries = append(registries, metrics.RegisterInfluxDB(ctx, metricsConfig.InfluxDB)) | ||||
| 		log.FromContext(ctx).Debugf("Configured InfluxDB metrics: pushing to %s once every %s", | ||||
| 			metricsConfig.InfluxDB.Address, metricsConfig.InfluxDB.PushInterval) | ||||
| 	if metricsConfig.InfluxDB2 != nil { | ||||
| 		logger := log.With().Str(logs.MetricsProviderName, "influxdb2").Logger() | ||||
|  | ||||
| 		influxDB2Register := metrics.RegisterInfluxDB2(logger.WithContext(context.Background()), metricsConfig.InfluxDB2) | ||||
| 		if influxDB2Register != nil { | ||||
| 			registries = append(registries, influxDB2Register) | ||||
| 			logger.Debug(). | ||||
| 				Str("address", metricsConfig.InfluxDB2.Address). | ||||
| 				Str("bucket", metricsConfig.InfluxDB2.Bucket). | ||||
| 				Str("organization", metricsConfig.InfluxDB2.Org). | ||||
| 				Str("pushInterval", metricsConfig.InfluxDB2.PushInterval.String()). | ||||
| 				Msg("Configured InfluxDB v2 metrics") | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if metricsConfig.OpenTelemetry != nil { | ||||
| 		logger := log.With().Str(logs.MetricsProviderName, "openTelemetry").Logger() | ||||
|  | ||||
| 		openTelemetryRegistry := metrics.RegisterOpenTelemetry(logger.WithContext(context.Background()), metricsConfig.OpenTelemetry) | ||||
| 		if openTelemetryRegistry != nil { | ||||
| 			registries = append(registries, openTelemetryRegistry) | ||||
| 			logger.Debug(). | ||||
| 				Str("address", metricsConfig.OpenTelemetry.Address). | ||||
| 				Str("pushInterval", metricsConfig.OpenTelemetry.PushInterval.String()). | ||||
| 				Msg("Configured OpenTelemetry metrics") | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return registries | ||||
| @@ -474,64 +553,85 @@ func setupAccessLog(conf *types.AccessLog) *accesslog.Handler { | ||||
|  | ||||
| 	accessLoggerMiddleware, err := accesslog.NewHandler(conf) | ||||
| 	if err != nil { | ||||
| 		log.WithoutContext().Warnf("Unable to create access logger : %v", err) | ||||
| 		log.Warn().Err(err).Msg("Unable to create access logger") | ||||
| 		return nil | ||||
| 	} | ||||
|  | ||||
| 	return accessLoggerMiddleware | ||||
| } | ||||
|  | ||||
| func configureLogging(staticConfiguration *static.Configuration) { | ||||
| 	// configure default log flags | ||||
| 	stdlog.SetFlags(stdlog.Lshortfile | stdlog.LstdFlags) | ||||
|  | ||||
| 	// configure log level | ||||
| 	// an explicitly defined log level always has precedence. if none is | ||||
| 	// given and debug mode is disabled, the default is ERROR, and DEBUG | ||||
| 	// otherwise. | ||||
| 	levelStr := "error" | ||||
| 	if staticConfiguration.Log != nil && staticConfiguration.Log.Level != "" { | ||||
| 		levelStr = strings.ToLower(staticConfiguration.Log.Level) | ||||
| func setupTracing(conf *static.Tracing) *tracing.Tracing { | ||||
| 	if conf == nil { | ||||
| 		return nil | ||||
| 	} | ||||
|  | ||||
| 	level, err := logrus.ParseLevel(levelStr) | ||||
| 	var backend tracing.Backend | ||||
|  | ||||
| 	if conf.Jaeger != nil { | ||||
| 		backend = conf.Jaeger | ||||
| 	} | ||||
|  | ||||
| 	if conf.Zipkin != nil { | ||||
| 		if backend != nil { | ||||
| 			log.Error().Msg("Multiple tracing backend are not supported: cannot create Zipkin backend.") | ||||
| 		} else { | ||||
| 			backend = conf.Zipkin | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if conf.Datadog != nil { | ||||
| 		if backend != nil { | ||||
| 			log.Error().Msg("Multiple tracing backend are not supported: cannot create Datadog backend.") | ||||
| 		} else { | ||||
| 			backend = conf.Datadog | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if conf.Instana != nil { | ||||
| 		if backend != nil { | ||||
| 			log.Error().Msg("Multiple tracing backend are not supported: cannot create Instana backend.") | ||||
| 		} else { | ||||
| 			backend = conf.Instana | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if conf.Haystack != nil { | ||||
| 		if backend != nil { | ||||
| 			log.Error().Msg("Multiple tracing backend are not supported: cannot create Haystack backend.") | ||||
| 		} else { | ||||
| 			backend = conf.Haystack | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if conf.Elastic != nil { | ||||
| 		if backend != nil { | ||||
| 			log.Error().Msg("Multiple tracing backend are not supported: cannot create Elastic backend.") | ||||
| 		} else { | ||||
| 			backend = conf.Elastic | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if conf.OpenTelemetry != nil { | ||||
| 		if backend != nil { | ||||
| 			log.Error().Msg("Tracing backends are all mutually exclusive: cannot create OpenTelemetry backend.") | ||||
| 		} else { | ||||
| 			backend = conf.OpenTelemetry | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if backend == nil { | ||||
| 		log.Debug().Msg("Could not initialize tracing, using Jaeger by default") | ||||
| 		defaultBackend := &jaeger.Config{} | ||||
| 		defaultBackend.SetDefaults() | ||||
| 		backend = defaultBackend | ||||
| 	} | ||||
|  | ||||
| 	tracer, err := tracing.NewTracing(conf.ServiceName, conf.SpanNameLimit, backend) | ||||
| 	if err != nil { | ||||
| 		log.WithoutContext().Errorf("Error getting level: %v", err) | ||||
| 	} | ||||
| 	log.SetLevel(level) | ||||
|  | ||||
| 	var logFile string | ||||
| 	if staticConfiguration.Log != nil && len(staticConfiguration.Log.FilePath) > 0 { | ||||
| 		logFile = staticConfiguration.Log.FilePath | ||||
| 	} | ||||
|  | ||||
| 	// configure log format | ||||
| 	var formatter logrus.Formatter | ||||
| 	if staticConfiguration.Log != nil && staticConfiguration.Log.Format == "json" { | ||||
| 		formatter = &logrus.JSONFormatter{} | ||||
| 	} else { | ||||
| 		disableColors := len(logFile) > 0 | ||||
| 		formatter = &logrus.TextFormatter{DisableColors: disableColors, FullTimestamp: true, DisableSorting: true} | ||||
| 	} | ||||
| 	log.SetFormatter(formatter) | ||||
|  | ||||
| 	if len(logFile) > 0 { | ||||
| 		dir := filepath.Dir(logFile) | ||||
|  | ||||
| 		if err := os.MkdirAll(dir, 0o755); err != nil { | ||||
| 			log.WithoutContext().Errorf("Failed to create log path %s: %s", dir, err) | ||||
| 		} | ||||
|  | ||||
| 		err = log.OpenFile(logFile) | ||||
| 		logrus.RegisterExitHandler(func() { | ||||
| 			if err := log.CloseFile(); err != nil { | ||||
| 				log.WithoutContext().Errorf("Error while closing log: %v", err) | ||||
| 			} | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			log.WithoutContext().Errorf("Error while opening log file %s: %v", logFile, err) | ||||
| 		} | ||||
| 		log.Warn().Err(err).Msg("Unable to create tracer") | ||||
| 		return nil | ||||
| 	} | ||||
| 	return tracer | ||||
| } | ||||
|  | ||||
| func checkNewVersion() { | ||||
| @@ -544,16 +644,16 @@ func checkNewVersion() { | ||||
| } | ||||
|  | ||||
| func stats(staticConfiguration *static.Configuration) { | ||||
| 	logger := log.WithoutContext() | ||||
| 	logger := log.Info() | ||||
|  | ||||
| 	if staticConfiguration.Global.SendAnonymousUsage { | ||||
| 		logger.Info(`Stats collection is enabled.`) | ||||
| 		logger.Info(`Many thanks for contributing to Traefik's improvement by allowing us to receive anonymous information from your configuration.`) | ||||
| 		logger.Info(`Help us improve Traefik by leaving this feature on :)`) | ||||
| 		logger.Info(`More details on: https://doc.traefik.io/traefik/contributing/data-collection/`) | ||||
| 		logger.Msg(`Stats collection is enabled.`) | ||||
| 		logger.Msg(`Many thanks for contributing to Traefik's improvement by allowing us to receive anonymous information from your configuration.`) | ||||
| 		logger.Msg(`Help us improve Traefik by leaving this feature on :)`) | ||||
| 		logger.Msg(`More details on: https://doc.traefik.io/traefik/contributing/data-collection/`) | ||||
| 		collect(staticConfiguration) | ||||
| 	} else { | ||||
| 		logger.Info(` | ||||
| 		logger.Msg(` | ||||
| Stats collection is disabled. | ||||
| Help us improve Traefik by turning this feature on :) | ||||
| More details on: https://doc.traefik.io/traefik/contributing/data-collection/ | ||||
| @@ -566,7 +666,7 @@ func collect(staticConfiguration *static.Configuration) { | ||||
| 	safe.Go(func() { | ||||
| 		for time.Sleep(10 * time.Minute); ; <-ticker { | ||||
| 			if err := collector.Collect(staticConfiguration); err != nil { | ||||
| 				log.WithoutContext().Debug(err) | ||||
| 				log.Debug().Err(err).Send() | ||||
| 			} | ||||
| 		} | ||||
| 	}) | ||||
|   | ||||
| @@ -9,6 +9,7 @@ import ( | ||||
| 	"github.com/go-kit/kit/metrics" | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| 	"github.com/stretchr/testify/require" | ||||
| 	"github.com/traefik/traefik/v3/pkg/config/static" | ||||
| ) | ||||
|  | ||||
| // FooCert is a PEM-encoded TLS cert. | ||||
| @@ -114,3 +115,79 @@ func TestAppendCertMetric(t *testing.T) { | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func TestGetDefaultsEntrypoints(t *testing.T) { | ||||
| 	testCases := []struct { | ||||
| 		desc        string | ||||
| 		entrypoints static.EntryPoints | ||||
| 		expected    []string | ||||
| 	}{ | ||||
| 		{ | ||||
| 			desc: "Skips special names", | ||||
| 			entrypoints: map[string]*static.EntryPoint{ | ||||
| 				"web": { | ||||
| 					Address: ":80", | ||||
| 				}, | ||||
| 				"traefik": { | ||||
| 					Address: ":8080", | ||||
| 				}, | ||||
| 				"traefikhub-api": { | ||||
| 					Address: ":9900", | ||||
| 				}, | ||||
| 				"traefikhub-tunl": { | ||||
| 					Address: ":9901", | ||||
| 				}, | ||||
| 			}, | ||||
| 			expected: []string{"web"}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			desc: "Two EntryPoints not attachable", | ||||
| 			entrypoints: map[string]*static.EntryPoint{ | ||||
| 				"web": { | ||||
| 					Address: ":80", | ||||
| 				}, | ||||
| 				"websecure": { | ||||
| 					Address: ":443", | ||||
| 				}, | ||||
| 			}, | ||||
| 			expected: []string{"web", "websecure"}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			desc: "Two EntryPoints only one attachable", | ||||
| 			entrypoints: map[string]*static.EntryPoint{ | ||||
| 				"web": { | ||||
| 					Address: ":80", | ||||
| 				}, | ||||
| 				"websecure": { | ||||
| 					Address:   ":443", | ||||
| 					AsDefault: true, | ||||
| 				}, | ||||
| 			}, | ||||
| 			expected: []string{"websecure"}, | ||||
| 		}, | ||||
| 		{ | ||||
| 			desc: "Two attachable EntryPoints", | ||||
| 			entrypoints: map[string]*static.EntryPoint{ | ||||
| 				"web": { | ||||
| 					Address:   ":80", | ||||
| 					AsDefault: true, | ||||
| 				}, | ||||
| 				"websecure": { | ||||
| 					Address:   ":443", | ||||
| 					AsDefault: true, | ||||
| 				}, | ||||
| 			}, | ||||
| 			expected: []string{"web", "websecure"}, | ||||
| 		}, | ||||
| 	} | ||||
|  | ||||
| 	for _, test := range testCases { | ||||
| 		t.Run(test.desc, func(t *testing.T) { | ||||
| 			actual := getDefaultsEntrypoints(&static.Configuration{ | ||||
| 				EntryPoints: test.entrypoints, | ||||
| 			}) | ||||
|  | ||||
| 			assert.ElementsMatch(t, test.expected, actual) | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -8,7 +8,7 @@ import ( | ||||
| 	"text/template" | ||||
|  | ||||
| 	"github.com/traefik/paerser/cli" | ||||
| 	"github.com/traefik/traefik/v2/pkg/version" | ||||
| 	"github.com/traefik/traefik/v3/pkg/version" | ||||
| ) | ||||
|  | ||||
| var versionTemplate = `Version:      {{.Version}} | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 58 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/content/assets/img/providers/nomad.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								docs/content/assets/img/providers/nomad.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 13 KiB | 
							
								
								
									
										
											BIN
										
									
								
								docs/content/assets/img/traefik.logo-dark.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								docs/content/assets/img/traefik.logo-dark.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 38 KiB | 
| @@ -8,8 +8,24 @@ description: "There are many ways to contribute to Traefik Proxy. If you're talk | ||||
| Spread the Love & Tell Us about It | ||||
| {: .subtitle } | ||||
|  | ||||
| There are many ways to contribute to the project, and there is one that always spark joy: when we see/read about users talking about how Traefik helps them solve their problems. | ||||
| Traefik Proxy was started by the community for the community. | ||||
| You can contribute to the Traefik community in three main ways: | ||||
|  | ||||
| If you're talking about Traefik, [let us know](https://blog.traefik.io/spread-the-love-ba5a40aa72e7) and we'll promote your enthusiasm! | ||||
| **Spread the word!** Guides, videos, blog posts, how-to articles, and showing off your network design all help spread the word about Traefik Proxy | ||||
| and teach others in the community how to best implement it. | ||||
| It always sparks joy when users share how Traefik Proxy helps them solve their problems. | ||||
| If you are talking about Traefik Proxy, [let us know](https://traefik.io/submit-my-contribution/) and we will promote your work and reward your enthusiasm! | ||||
| If you are giving a talk that includes or is about Traefik Proxy, [let us know](https://traefik.io/submit-my-contribution/) and we will send you swag and stickers for your time at the conference. | ||||
| If you have written about Traefik or shared useful information you would like to promote, feel free to add links to the [dedicated wiki page on GitHub](https://github.com/traefik/traefik/wiki/Awesome-Traefik). | ||||
|  | ||||
| Also, if you've written about Traefik or shared useful information you'd like to promote, feel free to add links in the [dedicated wiki page on Github](https://github.com/traefik/traefik/wiki/Awesome-Traefik). | ||||
| **Help community members!** Everyone needs a place to share their cool innovations or get help with that pesky bug that only a different pair of eyes seems to be able to see. | ||||
| Join our [Community Forum](https://community.traefik.io/) where you can ask questions, help out other users, and share your neat configuration examples or snippets. | ||||
| Top contributors will be asked to join the Ambassador program and get unique swag to celebrate! | ||||
|  | ||||
| **Build cool solutions!** Traefik Proxy would be so much better if only it had… | ||||
| We love all the wonderful ideas that our users come up with, but we can only build so much. | ||||
| Luckily, as an open source community, our users can help by [building awesome features](https://github.com/orgs/traefik/projects/9/views/7), enhancements, or bug fixes. | ||||
| We are a big community, so we do need to prioritize a bit. | ||||
| That is why we use the tag `contributor/wanted` to let you know which pull requests will make it to the front of the queue for design support and review. | ||||
| Feel free to grab one of these and run with it. | ||||
| Top contributors get unique swag to celebrate. | ||||
|   | ||||
| @@ -8,17 +8,22 @@ description: "Compile and test your own Traefik Proxy! Learn how to build your o | ||||
| Compile and Test Your Own Traefik! | ||||
| {: .subtitle } | ||||
|  | ||||
| So you want to build your own Traefik binary from the sources? | ||||
| You want to build your own Traefik binary from the sources? | ||||
| Let's see how. | ||||
|  | ||||
| ## Building | ||||
|  | ||||
| You need either [Docker](https://github.com/docker/docker) and `make` (Method 1), or `go` (Method 2) in order to build Traefik. | ||||
| You need either [Docker](https://github.com/docker/docker "Link to website of Docker") and `make` (Method 1), or [Go](https://go.dev/ "Link to website of Go") (Method 2) in order to build Traefik. | ||||
| For changes to its dependencies, the `dep` dependency management tool is required. | ||||
|  | ||||
| ### Method 1: Using `Docker` and `Makefile` | ||||
|  | ||||
| Run make with the `binary` target. | ||||
|  | ||||
| ```bash | ||||
| make binary | ||||
| ``` | ||||
|  | ||||
| This will create binaries for the Linux platform in the `dist` folder. | ||||
|  | ||||
| In case when you run build on CI, you may probably want to run docker in non-interactive mode. To achieve that define `DOCKER_NON_INTERACTIVE=true` environment variable. | ||||
| @@ -160,7 +165,7 @@ TESTFLAGS="-check.f MyTestSuite.My" make test-integration | ||||
| TESTFLAGS="-check.f MyTestSuite.*Test" make test-integration | ||||
| ``` | ||||
|  | ||||
| More: https://labix.org/gocheck | ||||
| Check [gocheck](https://labix.org/gocheck "Link to website of gocheck") for more information. | ||||
|  | ||||
| ### Method 2: `go` | ||||
|  | ||||
|   | ||||
| @@ -10,8 +10,8 @@ Understanding How Traefik is Being Used | ||||
|  | ||||
| ## Configuration Example | ||||
|  | ||||
| Understanding how you use Traefik is very important to us: it helps us improve the solution in many different ways.   | ||||
| For this very reason, the sendAnonymousUsage option is mandatory: we want you to take time to consider whether or not you wish to share anonymous data with us so we can benefit from your experience and use cases. | ||||
| Understanding how you use Traefik is very important to us: it helps us improve the solution in many different ways. | ||||
| For this very reason, the sendAnonymousUsage option is mandatory: we want you to take time to consider whether or not you wish to share anonymous data with us, so we can benefit from your experience and use cases. | ||||
|  | ||||
| !!! example "Enabling Data Collection" | ||||
|  | ||||
| @@ -34,9 +34,7 @@ For this very reason, the sendAnonymousUsage option is mandatory: we want you to | ||||
|  | ||||
| ## Collected Data | ||||
|  | ||||
| This feature comes from the public proposal [here](https://github.com/traefik/traefik/issues/2369). | ||||
|  | ||||
| This feature is activated when using Traefik Pilot to better understand the community's need, and also to get information about plug-ins popularity. | ||||
| This feature comes from this [public proposal](https://github.com/traefik/traefik/issues/2369). | ||||
|  | ||||
| In order to help us learn more about how Traefik is being used and improve it, we collect anonymous usage statistics from running instances. | ||||
| Those data help us prioritize our developments and focus on what's important for our users (for example, which provider is popular, and which is not). | ||||
| @@ -47,7 +45,7 @@ Once a day (the first call begins 10 minutes after the start of Traefik), we col | ||||
|  | ||||
| - the Traefik version number | ||||
| - a hash of the configuration | ||||
| - an **anonymized version** of the static configuration (token, user name, password, URL, IP, domain, email, etc, are removed). | ||||
| - an **anonymized version** of the static configuration (token, username, password, URL, IP, domain, email, etc., are removed). | ||||
|  | ||||
| !!! info | ||||
|  | ||||
| @@ -68,7 +66,6 @@ providers: | ||||
|   docker: | ||||
|     endpoint: "tcp://10.10.10.10:2375" | ||||
|     exposedByDefault: true | ||||
|     swarmMode: true | ||||
|  | ||||
|     tls: | ||||
|       ca: dockerCA | ||||
| @@ -88,7 +85,6 @@ providers: | ||||
|   docker: | ||||
|     endpoint: "xxxx" | ||||
|     exposedByDefault: true | ||||
|     swarmMode: true | ||||
|  | ||||
|     tls: | ||||
|       ca: xxxx | ||||
| @@ -101,4 +97,4 @@ providers: | ||||
|  | ||||
| If you want to dig into more details, here is the source code of the collecting system: [collector.go](https://github.com/traefik/traefik/blob/master/pkg/collector/collector.go) | ||||
|  | ||||
| By default we anonymize all configuration fields, except fields tagged with `export=true`. | ||||
| By default, we anonymize all configuration fields, except fields tagged with `export=true`. | ||||
|   | ||||
| @@ -15,10 +15,14 @@ Let's see how. | ||||
|  | ||||
| ### General | ||||
|  | ||||
| This [documentation](https://doc.traefik.io/traefik/) is built with [mkdocs](https://mkdocs.org/). | ||||
| This [documentation](https://doc.traefik.io/traefik/ "Link to the official Traefik documentation") is built with [MkDocs](https://mkdocs.org/ "Link to website of MkDocs"). | ||||
|  | ||||
| ### Method 1: `Docker` and `make` | ||||
|  | ||||
| Please make sure you have the following requirements installed: | ||||
|  | ||||
| - [Docker](https://www.docker.com/ "Link to website of Docker") | ||||
|  | ||||
| You can build the documentation and test it locally (with live reloading), using the `docs-serve` target: | ||||
|  | ||||
| ```bash | ||||
| @@ -43,9 +47,12 @@ $ make docs-build | ||||
| ... | ||||
| ``` | ||||
|  | ||||
| ### Method 2: `mkdocs` | ||||
| ### Method 2: `MkDocs` | ||||
|  | ||||
| First, make sure you have `python` and `pip` installed. | ||||
| Please make sure you have the following requirements installed: | ||||
|  | ||||
| - [Python](https://www.python.org/ "Link to website of Python") | ||||
| - [pip](https://pypi.org/project/pip/ "Link to the website of pip on PyPI") | ||||
|  | ||||
| ```bash | ||||
| $ python --version | ||||
| @@ -54,7 +61,7 @@ $ pip --version | ||||
| pip 1.5.2 | ||||
| ``` | ||||
|  | ||||
| Then, install mkdocs with `pip`. | ||||
| Then, install MkDocs with `pip`. | ||||
|  | ||||
| ```bash | ||||
| pip install --user -r requirements.txt | ||||
| @@ -87,7 +94,7 @@ Running ["HtmlCheck", "ImageCheck", "ScriptCheck", "LinkCheck"] on /app/site/bas | ||||
|  | ||||
| !!! note "Clean & Verify" | ||||
|  | ||||
|     If you've made changes to the documentation, it's safter to clean it before verifying it. | ||||
|     If you've made changes to the documentation, it's safer to clean it before verifying it. | ||||
|  | ||||
|     ```bash | ||||
|     $ make docs | ||||
|   | ||||
| @@ -11,7 +11,7 @@ Note: the document is a work in progress. | ||||
|  | ||||
| Welcome to the Traefik Community. | ||||
| This document describes how to be part of the core team | ||||
| as well as various responsibilities | ||||
| together with various responsibilities | ||||
| and guidelines for Traefik maintainers. | ||||
| We are strongly promoting a philosophy of openness and sharing, | ||||
| and firmly standing against the elitist closed approach. | ||||
| @@ -20,7 +20,7 @@ and wants to be part of that journey! | ||||
|  | ||||
| ## Onboarding Process | ||||
|  | ||||
| If you consider joining our community please drop us a line using Twitter or leave a note in the issue. | ||||
| If you consider joining our community, please drop us a line using Twitter or leave a note in the issue. | ||||
| We will schedule a quick call to meet you and learn more about your motivation. | ||||
| During the call, the team will discuss the process of becoming a maintainer. | ||||
| We will be happy to answer any questions and explain all your doubts. | ||||
| @@ -53,7 +53,7 @@ but we can suggest you start with activities such as: | ||||
|       Each of the issues that are labeled as bug/possible bug/confirmed requires a reproducible use case.  | ||||
|       You can help in creating a reproducible use case if it has not been added to the issue | ||||
|       or use the sample code provided by the reporter. | ||||
|       Typically, a simple docker compose should be enough to reproduce the issue. | ||||
|       Typically, a simple Docker Compose should be enough to reproduce the issue. | ||||
| - Code contribution. | ||||
| - Documentation contribution. | ||||
|     - Technical documentation is one of the most important components of the product. | ||||
| @@ -61,7 +61,7 @@ but we can suggest you start with activities such as: | ||||
|       using the official documentation, | ||||
|       is a game changer. | ||||
| - You will be listed on our Maintainers GitHub page | ||||
|   as well as on our website in the section [maintainers](maintainers.md). | ||||
|   and on our website in the section [maintainers](maintainers.md). | ||||
| - We will be promoting you on social channels (mostly on Twitter). | ||||
|  | ||||
| ## Governance | ||||
| @@ -71,7 +71,7 @@ but we can suggest you start with activities such as: | ||||
| ## Communicating | ||||
|  | ||||
| - All of our maintainers are added to Slack #traefik-maintainers channel that belongs to Traefik labs workspace. | ||||
|   Having the team in one place helps us to communicate effectively.  | ||||
|   Having the team in one place helps us to communicate effectively. | ||||
|   You can reach Traefik core developers directly, | ||||
|   which offers the possibility to discuss issues, pull requests, enhancements more efficiently | ||||
|   and get the feedback almost immediately. | ||||
| @@ -112,9 +112,9 @@ maintainers' activity and involvement will be reviewed on a regular basis. | ||||
|  | ||||
| - Be able to put yourself in users’ shoes. | ||||
| - Be open-minded and respectful with other maintainers and other community members. | ||||
| - Keep the communication public -  | ||||
| - Keep the communication public - | ||||
|   if anyone tries to communicate with you directly, | ||||
|   ask him politely to move the conversation to a public communication channel. | ||||
|   ask politely to move the conversation to a public communication channel. | ||||
| - Stay away from defensive comments. | ||||
| - Please try to express your thoughts clearly enough | ||||
|   and note that some of us are not native English speakers. | ||||
| @@ -122,7 +122,7 @@ maintainers' activity and involvement will be reviewed on a regular basis. | ||||
|   none of us is able to predict your thoughts. | ||||
| - There are a lot of use cases of using Traefik | ||||
|   and even more issues that are difficult to reproduce. | ||||
|   If the issue can’t be replicated due to a lack of reproducible case (a simple docker compose should be enough) -  | ||||
|   If the issue can’t be replicated due to a lack of reproducible case (a simple Docker Compose should be enough) - | ||||
|   set your time limits while working on the issue | ||||
|   and express clearly that you were not able to replicate it. | ||||
|   You can come back later to that case. | ||||
|   | ||||
| @@ -107,7 +107,6 @@ The `status/*` labels represent the desired state in the workflow. | ||||
| * `area/provider/kv`: KV related. | ||||
| * `area/provider/marathon`: Marathon related. | ||||
| * `area/provider/mesos`: Mesos related. | ||||
| * `area/provider/rancher`: Rancher related. | ||||
| * `area/provider/servicefabric`: Azure service fabric related. | ||||
| * `area/provider/zk`: Zoo Keeper related. | ||||
| * `area/rules`: Rules related. | ||||
|   | ||||
| @@ -8,42 +8,56 @@ description: "Help us help you! Learn how to submit an issue, following the guid | ||||
| Help Us Help You! | ||||
| {: .subtitle } | ||||
|  | ||||
| We use the [GitHub issue tracker](https://github.com/traefik/traefik/issues) to keep track of issues in Traefik.  | ||||
| Issues are perfect for requesting a feature/enhancement or reporting a suspected bug. | ||||
| We use the [GitHub issue tracker](https://github.com/traefik/traefik/issues) to keep track of issues in Traefik. | ||||
|  | ||||
| The process of sorting and checking the issues is a daunting task, and requires a lot of work (more than an hour a day ... just for sorting). | ||||
| To save us some time and get quicker feedback, be sure to follow the guide lines below. | ||||
| To help us (and other community members) quickly and effortlessly understand what you need, | ||||
| be sure to follow the guidelines below. | ||||
|  | ||||
| !!! important "Getting Help Vs Reporting an Issue" | ||||
|  | ||||
|     The issue tracker is not a general support forum, but a place to report bugs and asks for new features. | ||||
|  | ||||
|     For end-user related support questions, try using first: | ||||
|  | ||||
|     - the Traefik community forum: [](https://community.traefik.io/) | ||||
|     For end-user related support questions, try using the [Traefik Community Forum](https://community.traefik.io/) | ||||
|    [](https://community.traefik.io/) | ||||
|  | ||||
| ## Issue Title | ||||
|  | ||||
| The title must be short and descriptive. (~60 characters) | ||||
|  | ||||
| ## Description | ||||
| Examples: | ||||
|  | ||||
| Follow the [issue template](https://github.com/traefik/traefik/blob/master/.github/ISSUE_TEMPLATE.md) as much as possible. | ||||
|  | ||||
| Explain us in which conditions you encountered the issue, what is your context. | ||||
|  | ||||
| Remain as clear and concise as possible | ||||
|  | ||||
| Take time to polish the format of your message so we'll enjoy reading it and working on it.  | ||||
| Help the readers focus on what matters, and help them understand the structure of your message (see the [GitHub Markdown Syntax](https://docs.github.com/en/get-started/writing-on-github)). | ||||
| * Bug: Duplicate requests in access logs | ||||
| * Feature: Support TCP | ||||
|  | ||||
| ## Feature Request | ||||
|  | ||||
| Traefik is an open-source project and aims to be the best edge router possible. | ||||
| Traefik is an open source project and aims to be the best edge router possible. | ||||
|  | ||||
| Remember when asking for new features that these must be useful to the majority (and not only useful in edge case scenarios, or hack-like setups). | ||||
| Follow the [issue template](https://github.com/traefik/traefik/blob/master/.github/ISSUE_TEMPLATE/feature-request.yml) as much as possible. | ||||
|  | ||||
| Do you best to explain what you're looking for, and why it would improve Traefik for everyone.  | ||||
| Do your best to explain what you're looking for, and why it would improve Traefik for everyone. | ||||
| Be detailed and share the use-case(s) to allow us to see the value of your feature request as quickly as possible. | ||||
|  | ||||
| Features with a lot of positive interaction (claps, +1s, conversation about how this would impact them) indicate higher community interest and help us to prioritize. | ||||
|  | ||||
| If you are interested in creating a PR for your feature request, let us know in the issue, so we can work with you. | ||||
| It can take a lot of work to make sure a PR can integrate with our existing code and planning with the team ahead of time can make sure that your PR can be accepted and merged quickly. | ||||
|  | ||||
| ## Issues or Possible Bug Reports | ||||
|  | ||||
| Follow the [issue template](https://github.com/traefik/traefik/blob/master/.github/ISSUE_TEMPLATE/bug_report.yml) as much as possible. | ||||
|  | ||||
| Explain the conditions in which you encountered the issue; what is your context? | ||||
| Share any logs you may have, and make sure to share the steps it takes to reproduce your issue or bug. | ||||
|  | ||||
| Remain as clear and concise as possible. | ||||
|  | ||||
| Take time to polish the format of your message, so we'll enjoy reading it and working on it. | ||||
| Help your readers focus on what matters and help them understand the structure of your message (see the [GitHub Markdown Syntax](https://docs.github.com/en/get-started/writing-on-github)). | ||||
|  | ||||
| ## International English | ||||
|  | ||||
| Every maintainer / Traefik user is not a native English speaker, so if you feel sometimes that some messages sound rude, remember that it probably is a language barrier problem from someone willing to help you. | ||||
| Every maintainer / Traefik user is not a native English speaker, so if you sometimes feel that some messages sound rude, remember that it probably is a language barrier problem from someone willing to help you. | ||||
|   | ||||
| @@ -3,12 +3,229 @@ title: "Traefik Pull Requests Documentation" | ||||
| description: "Looking to contribute to Traefik Proxy? This guide will show you the guidelines for submitting a PR in our contributors guide repository." | ||||
| --- | ||||
|  | ||||
| # Submitting Pull Requests | ||||
| # Before You Submit a Pull Request | ||||
|  | ||||
| A Quick Guide for Efficient Contributions | ||||
| {: .subtitle } | ||||
| This guide is for contributors who already have a pull request to submit. | ||||
| If you are looking for information on setting up your developer environment | ||||
| and creating code to contribute to Traefik Proxy or related projects, | ||||
| see the [development guide](https://docs.traefik.io/contributing/building-testing/). | ||||
|  | ||||
| So you've decided to improve Traefik?  | ||||
| Thank You!  | ||||
| Looking for a way to contribute to Traefik Proxy? | ||||
| Check out this list of [Priority Issues](https://github.com/traefik/traefik/labels/contributor%2Fwanted), | ||||
| the [Good First Issue](https://github.com/traefik/traefik/labels/contributor%2Fgood-first-issue) list, | ||||
| or the list of [confirmed bugs](https://github.com/traefik/traefik/labels/kind%2Fbug%2Fconfirmed) waiting to be remedied. | ||||
|  | ||||
| Please review the [guidelines on creating PRs](https://github.com/traefik/contributors-guide/blob/master/pr_guidelines.md) for Traefik in our [contributors guide repository](https://github.com/traefik/contributors-guide). | ||||
| ## How We Prioritize | ||||
|  | ||||
| We wish we could review every pull request right away. | ||||
| Unfortunately, our team has to prioritize pull requests (PRs) for review | ||||
| (but we are welcoming new [maintainers](https://github.com/traefik/traefik/blob/master/docs/content/contributing/maintainers-guidelines.md) to speed this up, | ||||
| if you are interested, check it out and apply). | ||||
|  | ||||
| The PRs we are able to handle fastest are: | ||||
|  | ||||
| * Documentation updates. | ||||
| * Bug fixes. | ||||
| * Enhancements and Features with a `contributor/wanted` tag. | ||||
|  | ||||
| PRs that take more time to address include: | ||||
|  | ||||
| * Enhancements or Features without the `contributor/wanted` tag. | ||||
|  | ||||
| If you have an idea for an enhancement or feature that you would like to build, | ||||
| [create an issue](https://github.com/traefik/traefik/issues/new/choose) for it first | ||||
| and tell us you are interested in writing the PR. | ||||
| If an issue already exists, definitely comment on it to tell us you are interested in creating a PR. | ||||
|  | ||||
| This will allow us to communicate directly and let you know if it is something we would accept. | ||||
|  | ||||
| It also allows us to make sure you have all the information you need during the design phase | ||||
| so that it can be reviewed and merged quickly. | ||||
|  | ||||
| Read more about the [Triage process](https://github.com/traefik/contributors-guide/blob/master/issue_triage.md) in the docs. | ||||
|  | ||||
| ## The Pull Request Submit Process | ||||
|  | ||||
| Merging a PR requires the following steps to be completed before it is merged automatically. | ||||
|  | ||||
| * Make sure your pull request adheres to our best practices. These include: | ||||
|     * [Following project conventions](https://github.com/traefik/traefik/blob/master/docs/content/contributing/maintainers-guidelines.md); including using the PR Template. | ||||
|     * Make small pull requests. | ||||
|     * Solve only one problem at a time. | ||||
|     * Comment thoroughly. | ||||
|     * Do not open the PR from an organization repository. | ||||
|     * Keep "allows edit from maintainer" checked. | ||||
|     * Use semantic line breaks for documentation. | ||||
|     * Ensure your PR is not a draft. We do not review drafts, but do answer questions and confer with developers on them as needed. | ||||
| * Pass the validation check. | ||||
| * Pass all tests. | ||||
| * Receive 3 approving reviews maintainers. | ||||
|  | ||||
| ## Pull Request Review Cycle | ||||
|  | ||||
| Learn about our [Triage Process](https://github.com/traefik/contributors-guide/blob/master/issue_triage.md), | ||||
| in short, it looks like this: | ||||
|  | ||||
| * We triage every new PR or comment before entering it into the review process. | ||||
|     * We ensure that all prerequisites for review have been met. | ||||
|     * We check to make sure the use case meets our needs. | ||||
|     * We assign reviewers. | ||||
| * Design Review. | ||||
|     * This takes longer than other parts of the process. | ||||
|     * We review that there are no obvious conflicts with our codebase. | ||||
| * Code Review. | ||||
|     * We review the code in-depth and run tests. | ||||
|     * We may ask for changes here. | ||||
|     * During code review, we ask that you be reasonably responsive, | ||||
|       if a PR languishes in code review it is at risk of rejection, | ||||
|       or we may take ownership of the PR and the contributor will become a co-author. | ||||
| * Merge. | ||||
|     * Success! | ||||
|  | ||||
| !!! note | ||||
|  | ||||
|     Occasionally, we may freeze our codebase when working towards a specific feature or goal that could impact other development. | ||||
|     During this time, your pull request could remain unmerged while the release work is completed. | ||||
|  | ||||
| ## Run Local Verifications | ||||
|  | ||||
| You must run these local verifications before you submit your pull request to predict the pass or failure of continuous integration. | ||||
| Your PR will not be reviewed until these are green on the CI. | ||||
|  | ||||
| * `make validate` | ||||
| * `make pull-images` | ||||
| * `make test` | ||||
|  | ||||
| ## The Testing and Merge Workflow | ||||
|  | ||||
| Pull Requests are managed by the bot [Myrmica Lobicornis](https://github.com/traefik/lobicornis). | ||||
| This bot is responsible for verifying GitHub Checks (CI, Tests, etc), mergability, and minimum reviews. | ||||
| In addition, it rebases or merges with the base PR branch if needed. | ||||
| It performs several other housekeeping items | ||||
| and you can read more about those on the [README](https://github.com/traefik/lobicornis) for Lobicornis. | ||||
|  | ||||
| The maintainer giving the final LGTM must add the `status/3-needs-merge` label to trigger the merge bot. | ||||
|  | ||||
| By default, a squash-rebase merge will be carried out. | ||||
|  | ||||
| The status `status/4-merge-in-progress` is only used by the bot. | ||||
|  | ||||
| If the bot is not able to perform the merge, the label `bot/need-human-merge` is added. | ||||
| In such a situation, solve the conflicts/CI/... and then remove the label `bot/need-human-merge`. | ||||
|  | ||||
| To prevent the bot from automatically merging a PR, add the label `bot/no-merge`. | ||||
|  | ||||
| The label `bot/light-review` decreases the number of required LGTM from 3 to 1. | ||||
|  | ||||
| This label can be used when: | ||||
|  | ||||
| * Updating a dependency. | ||||
| * Merging branches back into the next version branch. | ||||
| * Submitting minor documentation changes. | ||||
| * Submitting changelog PRs. | ||||
|  | ||||
| ## Why Was My Pull Request Closed? | ||||
|  | ||||
| Traefik Proxy is made by the community for the community, | ||||
| as such the goal is to engage the community to make Traefik the best reverse proxy available. | ||||
| Part of this goal is maintaining a lean codebase and ensuring code velocity. | ||||
| unfortunately, this means that sometimes we will not be able to merge a pull request. | ||||
|  | ||||
| Because we respect the work you did, you will always be told why we are closing your pull request. | ||||
| If you do not agree with our decision, do not worry; closed pull requests are effortless to recreate, | ||||
| and little work is lost by closing a pull request that subsequently needs to be reopened. | ||||
|  | ||||
| Your pull request might be closed if: | ||||
|  | ||||
| * Your PR's design conflicts with our existing codebase in such a way that merging is not an option | ||||
|   and the work needed to make your pull request usable is too high. | ||||
|     * To prevent this, make sure you created an issue first | ||||
|       and think about including Traefik Proxy maintainers in your design phase to minimize conflicts. | ||||
| * Your PR is for an enhancement or feature that we will not use. | ||||
|     * Please remember to create an issue for any pull request **before** you create a PR | ||||
|       to ensure that your goal is something we can merge and that you have any design insight you might need from the team. | ||||
| * Your PR has been waiting for feedback from the contributor for over 90 days. | ||||
|  | ||||
| ## Why is My Pull Request Not Getting Reviewed | ||||
|  | ||||
| A few factors affect how long your pull request might wait for review. | ||||
|  | ||||
| We must prioritize which PRs we focus on. | ||||
| Our first priority is PRs we have identified as having high community engagement and broad applicability. | ||||
| We put our top priorities on our roadmap, and you can identify them by the `contributor/wanted` tag. | ||||
| These PRs will enter our review process the fastest. | ||||
|  | ||||
| Our second priority is bug fixes. | ||||
| Especially for bugs that have already been tagged with `bug/confirmed`. | ||||
| These reviews enter the process quickly. | ||||
|  | ||||
| If your PR does not meet the criteria above, | ||||
| it will take longer for us to review, as any PRs that do meet the criteria above will be prioritized. | ||||
|  | ||||
| Additionally, during the last few weeks of a milestone, we stop reviewing PRs to reduce churn and stabilize. | ||||
| We will resume after the release. | ||||
|  | ||||
| The second major reason that we deprioritize your PR is that you are not following best practices. | ||||
|  | ||||
| The most common failures to follow best practices are: | ||||
|  | ||||
| * You did not create an issue for the PR you wish to make. | ||||
|   If you do not create an issue before submitting your PR, | ||||
|   we will not be able to answer any design questions and let you know how likely your PR is to be merged. | ||||
| * You created pull requests that are too large to review. | ||||
|     * Break your pull requests up. | ||||
|       If you can extract whole ideas from your pull request and send those as pull requests of their own, | ||||
|       you should do that instead. | ||||
|       It is better to have many pull requests addressing one thing than one pull request addressing many things. | ||||
|     * Traefik Proxy is a fast-moving codebase — lock in your changes ASAP with your small pull request, | ||||
|       and make merges be someone else's problem. | ||||
|       We want every pull request to be useful on its own, | ||||
|       so use your best judgment on what should be a pull request vs. a commit. | ||||
| * You did not comment well. | ||||
|     * Comment everything. | ||||
|  | ||||
| Please remember that we are working internationally, cross-culturally, and with different use-cases. | ||||
| Your reviewer will not intuitively understand the problem the same way you do or solve it the same way you would. | ||||
| This is why every change you make must be explained, and your strategy for coding must also be explained. | ||||
|  | ||||
| * Your tests were inadequate or absent. | ||||
|     * If you do not know how to test your PR, please ask! | ||||
|       We will be happy to help you or suggest appropriate test cases. | ||||
|  | ||||
| If you have already followed the best practices and your PR still has not received a response, | ||||
| here are some things you can do to move the process along: | ||||
|  | ||||
| * If you have fixed all the issues from a review, | ||||
|   remember to re-request a review (using the designated button) to let your reviewer know that you are ready. | ||||
|   You can choose to comment with the changes you made. | ||||
| * Ping `@tfny` if you have not been assigned to a reviewer. | ||||
|  | ||||
| For more information on best practices, try these links: | ||||
|  | ||||
| * [How to Write a Git Commit Message - Chris Beams](https://chris.beams.io/posts/git-commit/) | ||||
| * [Distributed Git - Contributing to a Project (Commit Guidelines)](https://git-scm.com/book/en/v2/Distributed-Git-Contributing-to-a-Project) | ||||
| * [What’s with the 50/72 rule? - Preslav Rachev](https://preslav.me/2015/02/21/what-s-with-the-50-72-rule/) | ||||
| * [A Note About Git Commit Messages - Tim Pope](https://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html) | ||||
|  | ||||
| ## It's OK to Push Back | ||||
|  | ||||
| Sometimes reviewers make mistakes. | ||||
| It is OK to push back on changes your reviewer requested. | ||||
| If you have a good reason for doing something a certain way, you are absolutely allowed to debate the merits of a requested change. | ||||
| Both the reviewer and reviewee should strive to discuss these issues in a polite and respectful manner. | ||||
|  | ||||
| You might be overruled, but you might also prevail. | ||||
| We are pretty reasonable people. | ||||
|  | ||||
| Another phenomenon of open-source projects (where anyone can comment on any issue) is the dog-pile - | ||||
| your pull request gets so many comments from so many people it becomes hard to follow. | ||||
| In this situation, you can ask the primary reviewer (assignee) whether they want you to fork a new pull request | ||||
| to clear out all the comments. | ||||
| You do not have to fix every issue raised by every person who feels like commenting, | ||||
| but you should answer reasonable comments with an explanation. | ||||
|  | ||||
| ## Common Sense and Courtesy | ||||
|  | ||||
| No document can take the place of common sense and good taste. | ||||
| Use your best judgment, while you put a bit of thought into how your work can be made easier to review. | ||||
| If you do these things, your pull requests will get merged with less friction. | ||||
|   | ||||
| @@ -12,7 +12,7 @@ You can subscribe sending a mail to security+subscribe@traefik.io or on [the onl | ||||
|  | ||||
| ## CVE | ||||
|  | ||||
| Reported vulnerabilities can be found on  | ||||
| Reported vulnerabilities can be found on | ||||
| [cve.mitre.org](https://cve.mitre.org/cgi-bin/cvekey.cgi?keyword=traefik). | ||||
|  | ||||
| ## Report a Vulnerability | ||||
|   | ||||
| @@ -8,11 +8,11 @@ description: "Thank you to all those who have contributed! Traefik Proxy is an o | ||||
| _You_ Made It | ||||
| {: .subtitle} | ||||
|  | ||||
| Traefik truly is an [open-source project](https://github.com/traefik/traefik/), | ||||
| Traefik Proxy truly is an [open-source project](https://github.com/traefik/traefik/), | ||||
| and wouldn't have become what it is today without the help of our [many contributors](https://github.com/traefik/traefik/graphs/contributors) (at the time of writing this), | ||||
| not accounting for people having helped with issues, tests, comments, articles, ... or just enjoying it and letting others know. | ||||
| not accounting for people having helped with issues, tests, comments, articles, ... or just enjoy using Traefik Proxy and share with others. | ||||
|  | ||||
| So once again, thank you for your invaluable help on making Traefik such a good product. | ||||
| So once again, thank you for your invaluable help in making Traefik such a good product! | ||||
|  | ||||
| !!! question "Where to Go Next?" | ||||
|     If you want to: | ||||
|   | ||||
							
								
								
									
										23
									
								
								docs/content/deprecation/features.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								docs/content/deprecation/features.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| # Feature Deprecation Notices | ||||
|  | ||||
| This page is maintained and updated periodically to reflect our roadmap and any decisions around feature deprecation. | ||||
|  | ||||
| | Feature                                                                                                              | Deprecated | End of Support | Removal | | ||||
| |----------------------------------------------------------------------------------------------------------------------|------------|----------------|---------| | ||||
| | [Kubernetes CRDs API Version `traefik.io/v1alpha1`](#kubernetes-crds-api-version-traefikiov1alpha1)                  | N/A        | N/A            | 3.0     | | ||||
| | [Kubernetes Ingress API Version `networking.k8s.io/v1beta1`](#kubernetes-ingress-api-version-networkingk8siov1beta1) | N/A        | N/A            | 3.0     | | ||||
| | [CRD API Version `apiextensions.k8s.io/v1beta1`](#kubernetes-ingress-api-version-networkingk8siov1beta1)             | N/A        | N/A            | 3.0     | | ||||
|  | ||||
| ## Impact | ||||
|  | ||||
| ### Kubernetes CRDs API Version `traefik.io/v1alpha1` | ||||
|  | ||||
| The newly introduced Kubernetes CRD API Version `traefik.io/v1alpha1` will subsequently be removed in Traefik v3. The following version will be `traefik.io/v1`. | ||||
|  | ||||
| ### Kubernetes Ingress API Version `networking.k8s.io/v1beta1` | ||||
|  | ||||
| The Kubernetes Ingress API Version `networking.k8s.io/v1beta1` is removed in v3. Please use the API Group `networking.k8s.io/v1` instead. | ||||
|  | ||||
| ### Traefik CRD API Version `apiextensions.k8s.io/v1beta1` | ||||
|  | ||||
| The Traefik CRD API Version `apiextensions.k8s.io/v1beta1` is removed in v3. Please use the API Group `apiextensions.k8s.io/v1` instead. | ||||
| @@ -6,14 +6,18 @@ Below is a non-exhaustive list of versions and their maintenance status: | ||||
|  | ||||
| | Version | Release Date | Active Support     | Security Support |  | ||||
| |---------|--------------|--------------------|------------------| | ||||
| | 2.6     | Jan 24, 2022 |      Yes           |       Yes        | | ||||
| | 2.5     | Aug 17, 2021 | Ended Jan 24, 2022 |       No         | | ||||
| | 2.4     | Jan 19, 2021 | Ended Aug 17, 2021 |       No         | | ||||
| | 2.3     | Sep 23, 2020 | Ended Jan 19, 2021 |       No         | | ||||
| | 2.2     | Mar 25, 2020 | Ended Sep 23, 2020 |       No         | | ||||
| | 2.1     | Dec 11, 2019 | Ended Mar 25, 2020 |       No         | | ||||
| | 2.0     | Sep 16, 2019 | Ended Dec 11, 2019 |       No         | | ||||
| | 1.7     | Sep 24, 2018 | Ended Dec 31, 2021 |  Contact Support | | ||||
| | 2.10    | Apr 24, 2023 | Yes                | Yes              | | ||||
| | 2.9     | Oct 03, 2022 | Ended Apr 24, 2023 | No               | | ||||
| | 2.8     | Jun 29, 2022 | Ended Oct 03, 2022 | No               | | ||||
| | 2.7     | May 24, 2022 | Ended Jun 29, 2022 | No               | | ||||
| | 2.6     | Jan 24, 2022 | Ended May 24, 2022 | No               | | ||||
| | 2.5     | Aug 17, 2021 | Ended Jan 24, 2022 | No               | | ||||
| | 2.4     | Jan 19, 2021 | Ended Aug 17, 2021 | No               | | ||||
| | 2.3     | Sep 23, 2020 | Ended Jan 19, 2021 | No               | | ||||
| | 2.2     | Mar 25, 2020 | Ended Sep 23, 2020 | No               | | ||||
| | 2.1     | Dec 11, 2019 | Ended Mar 25, 2020 | No               | | ||||
| | 2.0     | Sep 16, 2019 | Ended Dec 11, 2019 | No               | | ||||
| | 1.7     | Sep 24, 2018 | Ended Dec 31, 2021 | Contact Support  | | ||||
|  | ||||
| ??? example "Active Support / Security Support" | ||||
|  | ||||
|   | ||||
| @@ -1,19 +1,34 @@ | ||||
| --- | ||||
| title: "Traefik Concepts Documentation" | ||||
| description: "Get started with Traefik Proxy. Read the technical documentation for an introduction into the key concepts behind our open source edge router." | ||||
| title: Concepts | ||||
| description: Traefik - base concepts and main features | ||||
| --- | ||||
|  | ||||
| # Concepts | ||||
|  | ||||
| Everything You Need to Know | ||||
| {: .subtitle } | ||||
| This page explains the base concepts of Traefik. | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## Introduction | ||||
|  | ||||
| Traefik is based on the concept of EntryPoints, Routers, Middlewares and Services. | ||||
|  | ||||
| The main features include dynamic configuration, automatic service discovery, and support for multiple backends and protocols. | ||||
|  | ||||
| 1. [EntryPoints](../routing/entrypoints.md "Link to docs about EntryPoints"): EntryPoints are the network entry points into Traefik. They define the port which will receive the packets, and whether to listen for TCP or UDP. | ||||
|  | ||||
| 2. [Routers](../routing/routers/index.md "Link to docs about routers"): A router is in charge of connecting incoming requests to the services that can handle them. | ||||
|  | ||||
| 3. [Middlewares](../middlewares/overview.md "Link to docs about middlewares"): Attached to the routers, middlewares can modify the requests or responses before they are sent to your service | ||||
|  | ||||
| 4. [Services](../routing/services/index.md "Link to docs about services"): Services are responsible for configuring how to reach the actual services that will eventually handle the incoming requests. | ||||
|  | ||||
| ## Edge Router | ||||
|  | ||||
| Traefik is an _Edge Router_, it means that it's the door to your platform, and that it intercepts and routes every incoming request: | ||||
| it knows all the logic and every rule that determine which services handle which requests (based on the [path](../routing/routers/index.md#rule), the [host](../routing/routers/index.md#rule), [headers](../routing/routers/index.md#rule), [and so on](../routing/routers/index.md#rule) ...). | ||||
| Traefik is an *Edge Router*, it means that it's the door to your platform, and that it intercepts and routes every incoming request: | ||||
| it knows all the logic and every [rule](../routing/routers/index.md#rule "Link to docs about routing rules") that determine which services handle which requests (based on the *path*, the *host*, *headers*, etc.). | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| ## Auto Service Discovery | ||||
|  | ||||
| @@ -21,7 +36,7 @@ Where traditionally edge routers (or reverse proxies) need a configuration file | ||||
|  | ||||
| Deploying your services, you attach information that tells Traefik the characteristics of the requests the services can handle. | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| It means that when a service is deployed, Traefik detects it immediately and updates the routing rules in real time. | ||||
| Similarly, when a service is removed from the infrastructure, the corresponding route is deleted accordingly. | ||||
| @@ -30,12 +45,16 @@ You no longer need to create and synchronize configuration files cluttered with | ||||
|  | ||||
| !!! info "Many different rules" | ||||
|  | ||||
|     In the example above, we used the request [path](../routing/routers/index.md#rule) to determine which service was in charge, but of course you can use many other different [rules](../routing/routers/index.md#rule). | ||||
|     In the example above, we used the request [path rule](../routing/routers/index.md#rule "Link to docs about routing rules") to determine which service was in charge. | ||||
|     Certainly, you can use many other different [rules](../routing/routers/index.md#rule "Link to docs about routing rules"). | ||||
|  | ||||
| !!! info "Updating the requests" | ||||
|  | ||||
|     In the [middleware](../middlewares/overview.md) section, you can learn about how to update the requests before forwarding them to the services. | ||||
|     In the [middleware](../middlewares/overview.md "Link to middleware documentation") section, you can learn about how to update the requests before forwarding them to the services. | ||||
|  | ||||
| !!! question "How does Traefik discover the services?" | ||||
|  | ||||
|     Traefik is able to use your cluster API to discover the services and read the attached information. In Traefik, these connectors are called [providers](../providers/overview.md) because they _provide_ the configuration to Traefik. To learn more about them, read the [provider overview](../providers/overview.md) section. | ||||
|     Traefik is able to use your cluster API to discover the services and read the attached information. | ||||
|     In Traefik, these connectors are called [providers](../providers/overview.md "Link to overview about Traefik providers") because they *provide* the configuration to Traefik. | ||||
|  | ||||
| {!traefik-for-business-applications.md!} | ||||
|   | ||||
| @@ -79,7 +79,7 @@ traefik --help | ||||
| # or | ||||
|  | ||||
| docker run traefik[:version] --help | ||||
| # ex: docker run traefik:v2.6 --help | ||||
| # ex: docker run traefik:v3.0 --help | ||||
| ``` | ||||
|  | ||||
| All available arguments can also be found [here](../reference/static-configuration/cli.md). | ||||
| @@ -93,3 +93,5 @@ All available environment variables can be found [here](../reference/static-conf | ||||
| All the configuration options are documented in their related section. | ||||
|  | ||||
| You can browse the available features in the menu, the [providers](../providers/overview.md), or the [routing section](../routing/overview.md) to see them in action. | ||||
|  | ||||
| {!traefik-for-business-applications.md!} | ||||
|   | ||||
| @@ -157,3 +157,97 @@ By default, the following headers are automatically added when proxying requests | ||||
|  | ||||
| For more details, | ||||
| please check out the [forwarded header](../routing/entrypoints.md#forwarded-headers) documentation. | ||||
|  | ||||
| ## How Traefik is Storing and Serving TLS Certificates? | ||||
|  | ||||
| ### Storing TLS Certificates | ||||
|  | ||||
| [TLS](../https/tls.md "Link to Traefik TLS docs") certificates are either provided directly by the [dynamic configuration](./configuration-overview.md#the-dynamic-configuration "Link to dynamic configuration overview") from [providers](../https/tls.md#user-defined "Link to the TLS configuration"), | ||||
| or by [ACME resolvers](../https/acme.md#providers "Link to ACME resolvers"), which act themselves as providers internally. | ||||
|  | ||||
| For each TLS certificate, Traefik produces an identifier used as a key to store it. | ||||
| This identifier is constructed as the alphabetically ordered concatenation of the SANs `DNSNames` and `IPAddresses` of the TLScertificate. | ||||
|  | ||||
| #### Examples: | ||||
|  | ||||
| | X509v3 Subject Alternative Name         | TLS Certificate Identifier  | | ||||
| |-----------------------------------------|-----------------------------| | ||||
| | `DNS:example.com, IP Address:127.0.0.1` | `127.0.0.1,example.com`     | | ||||
| | `DNS:example.com, DNS:*.example.com`    | `*.example.com,example.com` | | ||||
|  | ||||
| The identifier is used to store TLS certificates in order to be later used to handle TLS connections. | ||||
| This operation happens each time there are configuration changes. | ||||
|  | ||||
| If multiple TLS certificates are provided with the same SANs definition (same identifier), only the one processed first is kept. | ||||
| Because the dynamic configuration is aggregated from all providers, | ||||
| when processing it to gather TLS certificates, | ||||
| there is no guarantee of the order in which they would be processed. | ||||
| This means that along with configurations applied, it is possible that the TLS certificate retained for a given identifier differs. | ||||
|  | ||||
| ### Serving TLS Certificates | ||||
|  | ||||
| For each incoming connection, Traefik is serving the "best" matching TLS certificate for the provided server name. | ||||
|  | ||||
| The TLS certificate selection process narrows down the list of TLS certificates matching the server name, | ||||
| and then selects the last TLS certificate in this list after having ordered it by the identifier alphabetically. | ||||
|  | ||||
| #### Examples: | ||||
|  | ||||
| | Selected TLS Certificates Identifiers               | Sorted TLS Certificates Identifiers                 | Served Certificate Identifier | | ||||
| |-----------------------------------------------------|-----------------------------------------------------|-------------------------------| | ||||
| | `127.0.0.1,example.com`,`*.example.com,example.com` | `*.example.com,example.com`,`127.0.0.1,example.com` | `127.0.0.1,example.com`       | | ||||
| | `*.example.com,example.com`,`example.com`           | `*.example.com,example.com`,`example.com`           | `example.com`                 | | ||||
|  | ||||
| ### Caching TLS Certificates | ||||
|  | ||||
| While Traefik is serving the best matching TLS certificate for each incoming connection, | ||||
| the selection process cost for each incoming connection is avoided thanks to a cache mechanism. | ||||
|  | ||||
| Once a TLS certificate has been selected as the "best" TLS certificate for a server name, | ||||
| it is cached for an hour, avoiding the selection process for further connections. | ||||
|  | ||||
| Nonetheless, when a new configuration is applied, the cache is reset. | ||||
|  | ||||
| ## What does the "field not found" error mean? | ||||
|  | ||||
| ```shell | ||||
| error: field not found, node: -badField- | ||||
| ``` | ||||
|  | ||||
| The "field not found" error occurs, when an unknown property is encountered in the dynamic or static configuration. | ||||
|  | ||||
| One easy way to check whether a configuration file is well-formed, is to validate it with: | ||||
|  | ||||
| - [JSON Schema of the static configuration](https://json.schemastore.org/traefik-v2.json) | ||||
| - [JSON Schema of the dynamic configuration](https://json.schemastore.org/traefik-v2-file-provider.json) | ||||
|  | ||||
| ## Why are some resources (routers, middlewares, services...) not created/applied? | ||||
|  | ||||
| As a common tip, if a resource is dropped/not created by Traefik after the dynamic configuration was evaluated, | ||||
| one should look for an error in the logs. | ||||
|  | ||||
| If found, the error obviously confirms that something went wrong while creating the resource, | ||||
| and the message should help in figuring out the mistake(s) in the configuration, and how to fix it. | ||||
|  | ||||
| When using the file provider, | ||||
| one easy way to check if the dynamic configuration is well-formed is to validate it with the [JSON Schema of the dynamic configuration](https://json.schemastore.org/traefik-v2-file-provider.json). | ||||
|  | ||||
| ## Why does Let's Encrypt wildcard certificate renewal/generation with DNS challenge fail? | ||||
|  | ||||
| If you're trying to renew wildcard certificates, with DNS challenge, | ||||
| and you're getting errors such as: | ||||
|  | ||||
| ```txt | ||||
| msg="Error renewing certificate from LE: {example.com [*.example.com]}" | ||||
| providerName=letsencrypt.acme error="error: one or more domains had a problem: | ||||
| [example.com] acme: error presenting token: gandiv5: unexpected authZone example.com. for fqdn example.com." | ||||
| ``` | ||||
|  | ||||
| then it could be due to `CNAME` support. | ||||
|  | ||||
| In which case, you should make sure your infrastructure is properly set up for a | ||||
| `DNS` challenge that does not rely on `CNAME`, and you should try disabling `CNAME` support with: | ||||
|  | ||||
| ```bash | ||||
| LEGO_DISABLE_CNAME_SUPPORT=true | ||||
| ``` | ||||
|   | ||||
| @@ -16,12 +16,12 @@ You can install Traefik with the following flavors: | ||||
|  | ||||
| Choose one of the [official Docker images](https://hub.docker.com/_/traefik) and run it with one sample configuration file: | ||||
|  | ||||
| * [YAML](https://raw.githubusercontent.com/traefik/traefik/v2.6/traefik.sample.yml) | ||||
| * [TOML](https://raw.githubusercontent.com/traefik/traefik/v2.6/traefik.sample.toml) | ||||
| * [YAML](https://raw.githubusercontent.com/traefik/traefik/v3.0/traefik.sample.yml) | ||||
| * [TOML](https://raw.githubusercontent.com/traefik/traefik/v3.0/traefik.sample.toml) | ||||
|  | ||||
| ```bash | ||||
| docker run -d -p 8080:8080 -p 80:80 \ | ||||
|     -v $PWD/traefik.yml:/etc/traefik/traefik.yml traefik:v2.6 | ||||
|     -v $PWD/traefik.yml:/etc/traefik/traefik.yml traefik:v3.0 | ||||
| ``` | ||||
|  | ||||
| For more details, go to the [Docker provider documentation](../providers/docker.md) | ||||
| @@ -29,7 +29,7 @@ For more details, go to the [Docker provider documentation](../providers/docker. | ||||
| !!! tip | ||||
|  | ||||
|     * Prefer a fixed version than the latest that could be an unexpected version. | ||||
|     ex: `traefik:v2.6` | ||||
|     ex: `traefik:v3.0` | ||||
|     * Docker images are based from the [Alpine Linux Official image](https://hub.docker.com/_/alpine). | ||||
|     * Any orchestrator using docker images can fetch the official Traefik docker image. | ||||
|  | ||||
| @@ -44,13 +44,13 @@ Traefik can be installed in Kubernetes using the Helm chart from <https://github | ||||
|  | ||||
| Ensure that the following requirements are met: | ||||
|  | ||||
| * Kubernetes 1.14+ | ||||
| * Helm version 3.x is [installed](https://helm.sh/docs/intro/install/) | ||||
| * Kubernetes 1.16+ | ||||
| * Helm version 3.9+ is [installed](https://helm.sh/docs/intro/install/) | ||||
|  | ||||
| Add Traefik's chart repository to Helm: | ||||
| Add Traefik Labs chart repository to Helm: | ||||
|  | ||||
| ```bash | ||||
| helm repo add traefik https://helm.traefik.io/traefik | ||||
| helm repo add traefik https://traefik.github.io/charts | ||||
| ``` | ||||
|  | ||||
| You can update the chart repository by running: | ||||
| @@ -68,6 +68,9 @@ helm install traefik traefik/traefik | ||||
| !!! tip "Helm Features" | ||||
|  | ||||
|     All [Helm features](https://helm.sh/docs/intro/using_helm/) are supported. | ||||
|  | ||||
|     Examples are provided [here](https://github.com/traefik/traefik-helm-chart/blob/master/EXAMPLES.md).  | ||||
|  | ||||
|     For instance, installing the chart in a dedicated namespace: | ||||
|  | ||||
|     ```bash tab="Install in a Dedicated Namespace" | ||||
| @@ -83,8 +86,7 @@ helm install traefik traefik/traefik | ||||
|     as with [any helm chart](https://helm.sh/docs/intro/using_helm/#customizing-the-chart-before-installing). | ||||
|     {: #helm-custom-values } | ||||
|  | ||||
|     The values are not (yet) documented, but are self-explanatory: | ||||
|     you can look at the [default `values.yaml`](https://github.com/traefik/traefik-helm-chart/blob/master/traefik/values.yaml) file to explore possibilities. | ||||
|     All parameters are documented in the default [`values.yaml`](https://github.com/traefik/traefik-helm-chart/blob/master/traefik/values.yaml). | ||||
|  | ||||
|     You can also set Traefik command line flags using `additionalArguments`. | ||||
|     Example of installation with logging set to `DEBUG`: | ||||
| @@ -119,7 +121,7 @@ by defining and applying an IngressRoute CRD (`kubectl apply -f dashboard.yaml`) | ||||
|  | ||||
| ```yaml | ||||
| # dashboard.yaml | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: IngressRoute | ||||
| metadata: | ||||
|   name: dashboard | ||||
| @@ -178,3 +180,5 @@ And run it: | ||||
| ## Compile your Binary from the Sources | ||||
|  | ||||
| All the details are available in the [Contributing Guide](../contributing/building-testing.md) | ||||
|  | ||||
| {!traefik-for-business-applications.md!} | ||||
|   | ||||
							
								
								
									
										320
									
								
								docs/content/getting-started/quick-start-with-kubernetes.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										320
									
								
								docs/content/getting-started/quick-start-with-kubernetes.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,320 @@ | ||||
| --- | ||||
| title: "Traefik Getting Started With Kubernetes" | ||||
| description: "Looking to get started with Traefik Proxy? Read the technical documentation to learn a simple use case that leverages Kubernetes." | ||||
| --- | ||||
|  | ||||
| # Quick Start | ||||
|  | ||||
| A Simple Use Case of Traefik Proxy and Kubernetes | ||||
| {: .subtitle } | ||||
|  | ||||
| This guide is an introduction to using Traefik Proxy in a Kubernetes environment. | ||||
| The objective is to learn how to run an application behind a Traefik reverse proxy in Kubernetes. | ||||
| It presents and explains the basic blocks required to start with Traefik such as Ingress Controller, Ingresses, Deployments, static, and dynamic configuration. | ||||
|  | ||||
| ## Permissions and Accesses | ||||
|  | ||||
| Traefik uses the Kubernetes API to discover running services. | ||||
|  | ||||
| In order to use the Kubernetes API, Traefik needs some permissions. | ||||
| This [permission mechanism](https://kubernetes.io/docs/reference/access-authn-authz/rbac/) is based on roles defined by the cluster administrator. | ||||
| The role is then bound to an account used by an application, in this case, Traefik Proxy. | ||||
|  | ||||
| The first step is to create the role. | ||||
| The [`ClusterRole`](https://kubernetes.io/docs/reference/kubernetes-api/authorization-resources/cluster-role-v1/#ClusterRole) resource enumerates the resources and actions available for the role. | ||||
| In a file called `00-role.yml`, put the following `ClusterRole`: | ||||
|  | ||||
| ```yaml tab="00-role.yml" | ||||
| kind: ClusterRole | ||||
| apiVersion: rbac.authorization.k8s.io/v1 | ||||
| metadata: | ||||
|   name: traefik-role | ||||
|  | ||||
| rules: | ||||
|   - apiGroups: | ||||
|       - "" | ||||
|     resources: | ||||
|       - services | ||||
|       - endpoints | ||||
|       - secrets | ||||
|     verbs: | ||||
|       - get | ||||
|       - list | ||||
|       - watch | ||||
|   - apiGroups: | ||||
|       - extensions | ||||
|       - networking.k8s.io | ||||
|     resources: | ||||
|       - ingresses | ||||
|       - ingressclasses | ||||
|     verbs: | ||||
|       - get | ||||
|       - list | ||||
|       - watch | ||||
|   - apiGroups: | ||||
|       - extensions | ||||
|       - networking.k8s.io | ||||
|     resources: | ||||
|       - ingresses/status | ||||
|     verbs: | ||||
|       - update | ||||
| ``` | ||||
|  | ||||
| !!! info "You can find the reference for this file [there](../../reference/dynamic-configuration/kubernetes-crd/#rbac)." | ||||
|  | ||||
| The next step is to create a dedicated service account for Traefik. | ||||
| In a file called `00-account.yml`, put the following [`ServiceAccount`](https://kubernetes.io/docs/reference/kubernetes-api/authentication-resources/service-account-v1/#ServiceAccount) resource: | ||||
|  | ||||
| ```yaml tab="00-account.yml" | ||||
| apiVersion: v1 | ||||
| kind: ServiceAccount | ||||
| metadata: | ||||
|   name: traefik-account | ||||
| ``` | ||||
|  | ||||
| And then, bind the role on the account to apply the permissions and rules on the latter. In a file called `01-role-binding.yml`, put the | ||||
| following [`ClusterRoleBinding`](https://kubernetes.io/docs/reference/kubernetes-api/authorization-resources/cluster-role-binding-v1/#ClusterRoleBinding) resource: | ||||
|  | ||||
| ```yaml tab="01-role-binding.yml" | ||||
| kind: ClusterRoleBinding | ||||
| apiVersion: rbac.authorization.k8s.io/v1 | ||||
| metadata: | ||||
|   name: traefik-role-binding | ||||
|  | ||||
| roleRef: | ||||
|   apiGroup: rbac.authorization.k8s.io | ||||
|   kind: ClusterRole | ||||
|   name: traefik-role | ||||
| subjects: | ||||
|   - kind: ServiceAccount | ||||
|     name: traefik-account | ||||
|     namespace: default # Using "default" because we did not specify a namespace when creating the ClusterAccount. | ||||
| ``` | ||||
|  | ||||
| !!! info "`roleRef` is the Kubernetes reference to the role created in `00-role.yml`." | ||||
|  | ||||
| !!! info "`subjects` is the list of accounts reference." | ||||
|  | ||||
|     In this guide, it only contains the account created in `00-account.yml` | ||||
|  | ||||
| ## Deployment and Exposition | ||||
|  | ||||
| !!! info "This section can be managed with the help of the [Traefik Helm chart](../install-traefik/#use-the-helm-chart)." | ||||
|  | ||||
| The [ingress controller](https://traefik.io/glossary/kubernetes-ingress-and-ingress-controller-101/#what-is-a-kubernetes-ingress-controller) | ||||
| is a software that runs in the same way as any other application on a cluster. | ||||
| To start Traefik on the Kubernetes cluster, | ||||
| a [`Deployment`](https://kubernetes.io/docs/reference/kubernetes-api/workload-resources/deployment-v1/) resource must exist to describe how to configure | ||||
| and scale containers horizontally to support larger workloads. | ||||
|  | ||||
| Start by creating a file called `02-traefik.yml` and paste the following `Deployment` resource: | ||||
|  | ||||
| ```yaml tab="02-traefik.yml" | ||||
| kind: Deployment | ||||
| apiVersion: apps/v1 | ||||
| metadata: | ||||
|   name: traefik-deployment | ||||
|   labels: | ||||
|     app: traefik | ||||
|  | ||||
| spec: | ||||
|   replicas: 1 | ||||
|   selector: | ||||
|     matchLabels: | ||||
|       app: traefik | ||||
|   template: | ||||
|     metadata: | ||||
|       labels: | ||||
|         app: traefik | ||||
|     spec: | ||||
|       serviceAccountName: traefik-account | ||||
|       containers: | ||||
|         - name: traefik | ||||
|           image: traefik:v3.0 | ||||
|           args: | ||||
|             - --api.insecure | ||||
|             - --providers.kubernetesingress | ||||
|           ports: | ||||
|             - name: web | ||||
|               containerPort: 80 | ||||
|             - name: dashboard | ||||
|               containerPort: 8080 | ||||
| ``` | ||||
|  | ||||
| The deployment contains an important attribute for customizing Traefik: `args`. | ||||
| These arguments are the static configuration for Traefik. | ||||
| From here, it is possible to enable the dashboard, | ||||
| configure entry points, | ||||
| select dynamic configuration providers, | ||||
| and [more](../reference/static-configuration/cli.md)... | ||||
|  | ||||
| In this deployment, | ||||
| the static configuration enables the Traefik dashboard, | ||||
| and uses Kubernetes native Ingress resources as router definitions to route incoming requests. | ||||
|  | ||||
| !!! info "When there is no entry point in the static configuration" | ||||
|  | ||||
|     Traefik creates a default one called `web` using the port `80` routing HTTP requests. | ||||
|  | ||||
| !!! info "When enabling the [`api.insecure`](../../operations/api/#insecure) mode, Traefik exposes the dashboard on the port `8080`." | ||||
|  | ||||
| A deployment manages scaling and then can create lots of containers, called [Pods](https://kubernetes.io/docs/concepts/workloads/pods/). | ||||
| Each Pod is configured following the `spec` field in the deployment. | ||||
| Given that, a Deployment can run multiple Traefik Proxy Pods, | ||||
| a piece is required to forward the traffic to any of the instance: | ||||
| namely a [`Service`](https://kubernetes.io/docs/reference/kubernetes-api/service-resources/service-v1/#Service). | ||||
| Create a file called `02-traefik-services.yml` and insert the two `Service` resources: | ||||
|  | ||||
| ```yaml tab="02-traefik-services.yml" | ||||
| apiVersion: v1 | ||||
| kind: Service | ||||
| metadata: | ||||
|   name: traefik-dashboard-service | ||||
|  | ||||
| spec: | ||||
|   type: LoadBalancer | ||||
|   ports: | ||||
|     - port: 8080 | ||||
|       targetPort: dashboard | ||||
|   selector: | ||||
|     app: traefik | ||||
| --- | ||||
| apiVersion: v1 | ||||
| kind: Service | ||||
| metadata: | ||||
|   name: traefik-web-service | ||||
|  | ||||
| spec: | ||||
|   type: LoadBalancer | ||||
|   ports: | ||||
|     - targetPort: web | ||||
|       port: 80 | ||||
|   selector: | ||||
|     app: traefik | ||||
| ``` | ||||
|  | ||||
| !!! warning "It is possible to expose a service in different ways." | ||||
|  | ||||
|     Depending on your working environment and use case, the `spec.type` might change. | ||||
|     It is strongly recommended to understand the available [service types](https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types) before proceeding to the next step. | ||||
|  | ||||
| It is now time to apply those files on your cluster to start Traefik. | ||||
|  | ||||
| ```shell | ||||
| kubectl apply -f 00-role.yml \ | ||||
|               -f 00-account.yml \ | ||||
|               -f 01-role-binding.yml \ | ||||
|               -f 02-traefik.yml \ | ||||
|               -f 02-traefik-services.yml | ||||
| ``` | ||||
|  | ||||
| ## Proxying applications | ||||
|  | ||||
| The only part still missing is the business application behind the reverse proxy. | ||||
| For this guide, we use the example application [traefik/whoami](https://github.com/traefik/whoami), | ||||
| but the principles are applicable to any other application. | ||||
|  | ||||
| The `whoami` application is a simple HTTP server running on port 80 which answers host-related information to the incoming requests. | ||||
| As usual, start by creating a file called `03-whoami.yml` and paste the following `Deployment` resource: | ||||
|  | ||||
| ```yaml tab="03-whoami.yml" | ||||
| kind: Deployment | ||||
| apiVersion: apps/v1 | ||||
| metadata: | ||||
|   name: whoami | ||||
|   labels: | ||||
|     app: whoami | ||||
|  | ||||
| spec: | ||||
|   replicas: 1 | ||||
|   selector: | ||||
|     matchLabels: | ||||
|       app: whoami | ||||
|   template: | ||||
|     metadata: | ||||
|       labels: | ||||
|         app: whoami | ||||
|     spec: | ||||
|       containers: | ||||
|         - name: whoami | ||||
|           image: traefik/whoami | ||||
|           ports: | ||||
|             - name: web | ||||
|               containerPort: 80 | ||||
| ``` | ||||
|  | ||||
| And continue by creating the following `Service` resource in a file called `03-whoami-services.yml`: | ||||
|  | ||||
| ```yaml tab="03-whoami-services.yml" | ||||
| apiVersion: v1 | ||||
| kind: Service | ||||
| metadata: | ||||
|   name: whoami | ||||
|  | ||||
| spec: | ||||
|   ports: | ||||
|     - name: web | ||||
|       port: 80 | ||||
|       targetPort: web | ||||
|        | ||||
|   selector: | ||||
|     app: whoami | ||||
| ``` | ||||
|  | ||||
| Thanks to the Kubernetes API, | ||||
| Traefik is notified when an Ingress resource is created, updated, or deleted. | ||||
| This makes the process dynamic. | ||||
| The ingresses are, in a way, the [dynamic configuration](../../providers/kubernetes-ingress/) for Traefik. | ||||
|  | ||||
| !!! tip | ||||
|  | ||||
|     Find more information on [ingress controller](https://kubernetes.io/docs/concepts/services-networking/ingress-controllers/), | ||||
|     and [Ingress](https://kubernetes.io/docs/concepts/services-networking/ingress/) in the official Kubernetes documentation. | ||||
|  | ||||
| Create a file called `04-whoami-ingress.yml` and insert the `Ingress` resource: | ||||
|  | ||||
| ```yaml tab="04-whoami-ingress.yml" | ||||
| apiVersion: networking.k8s.io/v1 | ||||
| kind: Ingress | ||||
| metadata: | ||||
|   name: whoami-ingress | ||||
| spec: | ||||
|   rules: | ||||
|   - http: | ||||
|       paths: | ||||
|       - path: / | ||||
|         pathType: Prefix | ||||
|         backend: | ||||
|           service: | ||||
|             name: whoami | ||||
|             port: | ||||
|               name: web | ||||
| ``` | ||||
|  | ||||
| This `Ingress` configures Traefik to redirect any incoming requests starting with `/` to the `whoami:80` service. | ||||
|  | ||||
| At this point, all the configurations are ready. | ||||
| It is time to apply those new files: | ||||
|  | ||||
| ```shell | ||||
| kubectl apply -f 03-whoami.yml \ | ||||
|               -f 03-whoami-services.yml \ | ||||
|               -f 04-whoami-ingress.yml | ||||
| ``` | ||||
|  | ||||
| Now you should be able to access the `whoami` application and the Traefik dashboard. | ||||
| Load the dashboard on a web browser: [`http://localhost:8080`](http://localhost:8080). | ||||
|  | ||||
| And now access the `whoami` application: | ||||
|  | ||||
| ```shell | ||||
| curl -v http://localhost/ | ||||
| ``` | ||||
|  | ||||
| !!! question "Going further" | ||||
|  | ||||
|     - [Filter the ingresses](../providers/kubernetes-ingress.md#ingressclass) to use with [IngressClass](https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class) | ||||
|     - Use [IngressRoute CRD](../providers/kubernetes-crd.md) | ||||
|     - Protect [ingresses with TLS](../routing/providers/kubernetes-ingress.md#enabling-tls-via-annotations) | ||||
|      | ||||
| {!traefik-api-management-kubernetes.md!} | ||||
| @@ -1,11 +1,11 @@ | ||||
| --- | ||||
| title: "Traefik Getting Started Quickly" | ||||
| description: "Looking to get started with Traefik Proxy quickly? Read the technical documentation to learn a simple use case that leverages Docker." | ||||
| description: "Looking to get started with Traefik Proxy quickly? Read the technical documentation to see a basic use case that leverages Docker." | ||||
| --- | ||||
|  | ||||
| # Quick Start | ||||
|  | ||||
| A Simple Use Case Using Docker | ||||
| A Basic Use Case Using Docker | ||||
| {: .subtitle } | ||||
|  | ||||
|  | ||||
| @@ -19,9 +19,9 @@ version: '3' | ||||
|  | ||||
| services: | ||||
|   reverse-proxy: | ||||
|     # The official v2 Traefik docker image | ||||
|     image: traefik:v2.6 | ||||
|     # Enables the web UI and tells Traefik to listen to docker | ||||
|     # The official v3 Traefik Docker image | ||||
|     image: traefik:v3.0 | ||||
|     # Enables the web UI and tells Traefik to listen to Docker | ||||
|     command: --api.insecure=true --providers.docker | ||||
|     ports: | ||||
|       # The HTTP port | ||||
| @@ -50,7 +50,12 @@ Now that we have a Traefik instance up and running, we will deploy new services. | ||||
| Edit your `docker-compose.yml` file and add the following at the end of your file. | ||||
|  | ||||
| ```yaml | ||||
| # ... | ||||
| version: '3' | ||||
|  | ||||
| services: | ||||
|  | ||||
|   ... | ||||
|  | ||||
|   whoami: | ||||
|     # A container that exposes an API to show its IP address | ||||
|     image: traefik/whoami | ||||
| @@ -58,7 +63,7 @@ Edit your `docker-compose.yml` file and add the following at the end of your fil | ||||
|       - "traefik.http.routers.whoami.rule=Host(`whoami.docker.localhost`)" | ||||
| ``` | ||||
|  | ||||
| The above defines `whoami`: a simple web service that outputs information about the machine it is deployed on (its IP address, host, and so on). | ||||
| The above defines [`whoami`](https://github.com/traefik/whoami "Link to whoami app on GitHub"), a web service that outputs information about the machine it is deployed on (its IP address, host, etc.). | ||||
|  | ||||
| Start the `whoami` service with the following command: | ||||
|  | ||||
| @@ -66,9 +71,9 @@ Start the `whoami` service with the following command: | ||||
| docker-compose up -d whoami | ||||
| ``` | ||||
|  | ||||
| Go back to your browser (`http://localhost:8080/api/rawdata`) and see that Traefik has automatically detected the new container and updated its own configuration. | ||||
| Browse `http://localhost:8080/api/rawdata` and see that Traefik has automatically detected the new container and updated its own configuration. | ||||
|  | ||||
| When Traefik detects new services, it creates the corresponding routes so you can call them ... _let's see!_  (Here, we're using curl) | ||||
| When Traefik detects new services, it creates the corresponding routes, so you can call them ... _let's see!_  (Here, we're using curl) | ||||
|  | ||||
| ```shell | ||||
| curl -H Host:whoami.docker.localhost http://127.0.0.1 | ||||
| @@ -90,7 +95,7 @@ Run more instances of your `whoami` service with the following command: | ||||
| docker-compose up -d --scale whoami=2 | ||||
| ``` | ||||
|  | ||||
| Go back to your browser (`http://localhost:8080/api/rawdata`) and see that Traefik has automatically detected the new instance of the container. | ||||
| Browse to `http://localhost:8080/api/rawdata` and see that Traefik has automatically detected the new instance of the container. | ||||
|  | ||||
| Finally, see that Traefik load-balances between the two instances of your service by running the following command twice: | ||||
|  | ||||
| @@ -113,4 +118,7 @@ IP: 172.27.0.4 | ||||
| ``` | ||||
|  | ||||
| !!! question "Where to Go Next?" | ||||
|     Now that you have a basic understanding of how Traefik can automatically create the routes to your services and load balance them, it is time to dive into [the documentation](/) and let Traefik work for you! | ||||
|  | ||||
|     Now that you have a basic understanding of how Traefik can automatically create the routes to your services and load balance them, it is time to dive into [the documentation](/ "Link to the docs landing page") and let Traefik work for you! | ||||
|  | ||||
| {!traefik-for-business-applications.md!} | ||||
|   | ||||
| @@ -11,7 +11,11 @@ Automatic HTTPS | ||||
| You can configure Traefik to use an ACME provider (like Let's Encrypt) for automatic certificate generation. | ||||
|  | ||||
| !!! warning "Let's Encrypt and Rate Limiting" | ||||
|     Note that Let's Encrypt API has [rate limiting](https://letsencrypt.org/docs/rate-limits). | ||||
|     Note that Let's Encrypt API has [rate limiting](https://letsencrypt.org/docs/rate-limits). These last up to __one week__, and can not be overridden. | ||||
|      | ||||
|     When running Traefik in a container this file should be persisted across restarts.  | ||||
|     If Traefik requests new certificates each time it starts up, a crash-looping container can quickly reach Let's Encrypt's ratelimits. | ||||
|     To configure where certificates are stored, please take a look at the [storage](#storage) configuration. | ||||
|  | ||||
|     Use Let's Encrypt staging server with the [`caServer`](#caserver) configuration option | ||||
|     when experimenting to avoid hitting this limit too fast. | ||||
| @@ -279,8 +283,19 @@ Use the `DNS-01` challenge to generate and renew ACME certificates by provisioni | ||||
|     # ... | ||||
|     ``` | ||||
|  | ||||
|     !!! important | ||||
|         A `provider` is mandatory. | ||||
| !!! warning "`CNAME` support" | ||||
|  | ||||
|     `CNAME` are supported (and sometimes even [encouraged](https://letsencrypt.org/2019/10/09/onboarding-your-customers-with-lets-encrypt-and-acme.html#the-advantages-of-a-cname)), | ||||
|     but there are a few cases where they can be [problematic](../../getting-started/faq/#why-does-lets-encrypt-wildcard-certificate-renewalgeneration-with-dns-challenge-fail). | ||||
|  | ||||
|     If needed, `CNAME` support can be disabled with the following environment variable: | ||||
|  | ||||
|     ```bash | ||||
|     LEGO_DISABLE_CNAME_SUPPORT=true | ||||
|     ``` | ||||
|  | ||||
| !!! important | ||||
|     A `provider` is mandatory. | ||||
|  | ||||
| #### `providers` | ||||
|  | ||||
| @@ -293,109 +308,127 @@ For example, `CF_API_EMAIL_FILE=/run/secrets/traefik_cf-api-email` could be used | ||||
|  | ||||
| For complete details, refer to your provider's _Additional configuration_ link. | ||||
|  | ||||
| | Provider Name                                               | Provider Code  | Environment Variables                                                                                                                       |                                                                             | | ||||
| |-------------------------------------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------| | ||||
| | [ACME DNS](https://github.com/joohoi/acme-dns)              | `acme-dns`     | `ACME_DNS_API_BASE`, `ACME_DNS_STORAGE_PATH`                                                                                                | [Additional configuration](https://go-acme.github.io/lego/dns/acme-dns)     | | ||||
| | [Alibaba Cloud](https://www.alibabacloud.com)               | `alidns`       | `ALICLOUD_ACCESS_KEY`, `ALICLOUD_SECRET_KEY`, `ALICLOUD_REGION_ID`                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/alidns)       | | ||||
| | [all-inkl](https://all-inkl.com)                            | `allinkl`      | `ALL_INKL_LOGIN`, `ALL_INKL_PASSWORD`                                                                                                       | [Additional configuration](https://go-acme.github.io/lego/dns/allinkl)      | | ||||
| | [ArvanCloud](https://www.arvancloud.com/en)                 | `arvancloud`   | `ARVANCLOUD_API_KEY`                                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/arvancloud)   | | ||||
| | [Auroradns](https://www.pcextreme.com/dns-health-checks)    | `auroradns`    | `AURORA_USER_ID`, `AURORA_KEY`, `AURORA_ENDPOINT`                                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/auroradns)    | | ||||
| | [Autodns](https://www.internetx.com/domains/autodns/)       | `autodns`      | `AUTODNS_API_USER`, `AUTODNS_API_PASSWORD`                                                                                                  | [Additional configuration](https://go-acme.github.io/lego/dns/autodns)      | | ||||
| | [Azure](https://azure.microsoft.com/services/dns/)          | `azure`        | `AZURE_CLIENT_ID`, `AZURE_CLIENT_SECRET`, `AZURE_SUBSCRIPTION_ID`, `AZURE_TENANT_ID`, `AZURE_RESOURCE_GROUP`, `[AZURE_METADATA_ENDPOINT]`   | [Additional configuration](https://go-acme.github.io/lego/dns/azure)        | | ||||
| | [Bindman](https://github.com/labbsr0x/bindman-dns-webhook)  | `bindman`      | `BINDMAN_MANAGER_ADDRESS`                                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/bindman)      | | ||||
| | [Blue Cat](https://www.bluecatnetworks.com/)                | `bluecat`      | `BLUECAT_SERVER_URL`, `BLUECAT_USER_NAME`, `BLUECAT_PASSWORD`, `BLUECAT_CONFIG_NAME`, `BLUECAT_DNS_VIEW`                                    | [Additional configuration](https://go-acme.github.io/lego/dns/bluecat)      | | ||||
| | [Checkdomain](https://www.checkdomain.de/)                  | `checkdomain`  | `CHECKDOMAIN_TOKEN`,                                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/checkdomain/) | | ||||
| | [CloudDNS](https://vshosting.eu/)                           | `clouddns`     | `CLOUDDNS_CLIENT_ID`, `CLOUDDNS_EMAIL`, `CLOUDDNS_PASSWORD`                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/clouddns)     | | ||||
| | [Cloudflare](https://www.cloudflare.com)                    | `cloudflare`   | `CF_API_EMAIL`, `CF_API_KEY` [^5] or `CF_DNS_API_TOKEN`, `[CF_ZONE_API_TOKEN]`                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/cloudflare)   | | ||||
| | [ClouDNS](https://www.cloudns.net/)                         | `cloudns`      | `CLOUDNS_AUTH_ID`, `CLOUDNS_AUTH_PASSWORD`                                                                                                  | [Additional configuration](https://go-acme.github.io/lego/dns/cloudns)      | | ||||
| | [CloudXNS](https://www.cloudxns.net)                        | `cloudxns`     | `CLOUDXNS_API_KEY`, `CLOUDXNS_SECRET_KEY`                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/cloudxns)     | | ||||
| | [ConoHa](https://www.conoha.jp)                             | `conoha`       | `CONOHA_TENANT_ID`, `CONOHA_API_USERNAME`, `CONOHA_API_PASSWORD`                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/conoha)       | | ||||
| | [Constellix](https://constellix.com)                        | `constellix`   | `CONSTELLIX_API_KEY`, `CONSTELLIX_SECRET_KEY`                                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/constellix)   | | ||||
| | [deSEC](https://desec.io)                                   | `desec`        | `DESEC_TOKEN`                                                                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/desec)        | | ||||
| | [DigitalOcean](https://www.digitalocean.com)                | `digitalocean` | `DO_AUTH_TOKEN`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/digitalocean) | | ||||
| | [DNS Made Easy](https://dnsmadeeasy.com)                    | `dnsmadeeasy`  | `DNSMADEEASY_API_KEY`, `DNSMADEEASY_API_SECRET`, `DNSMADEEASY_SANDBOX`                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/dnsmadeeasy)  | | ||||
| | [DNSimple](https://dnsimple.com)                            | `dnsimple`     | `DNSIMPLE_OAUTH_TOKEN`, `DNSIMPLE_BASE_URL`                                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/dnsimple)     | | ||||
| | [DNSPod](https://www.dnspod.com/)                           | `dnspod`       | `DNSPOD_API_KEY`                                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/dnspod)       | | ||||
| | [Domain Offensive (do.de)](https://www.do.de/)              | `dode`         | `DODE_TOKEN`                                                                                                                                | [Additional configuration](https://go-acme.github.io/lego/dns/dode)         | | ||||
| | [Domeneshop](https://domene.shop)                           | `domeneshop`   | `DOMENESHOP_API_TOKEN`, `DOMENESHOP_API_SECRET`                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/domeneshop)   | | ||||
| | [DreamHost](https://www.dreamhost.com/)                     | `dreamhost`    | `DREAMHOST_API_KEY`                                                                                                                         | [Additional configuration](https://go-acme.github.io/lego/dns/dreamhost)    | | ||||
| | [Duck DNS](https://www.duckdns.org/)                        | `duckdns`      | `DUCKDNS_TOKEN`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/duckdns)      | | ||||
| | [Dyn](https://dyn.com)                                      | `dyn`          | `DYN_CUSTOMER_NAME`, `DYN_USER_NAME`, `DYN_PASSWORD`                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/dyn)          | | ||||
| | [Dynu](https://www.dynu.com)                                | `dynu`         | `DYNU_API_KEY`                                                                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/dynu)         | | ||||
| | [EasyDNS](https://easydns.com/)                             | `easydns`      | `EASYDNS_TOKEN`, `EASYDNS_KEY`                                                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/easydns)      | | ||||
| | [EdgeDNS](https://www.akamai.com/)                          | `edgedns`      | `AKAMAI_CLIENT_TOKEN`,  `AKAMAI_CLIENT_SECRET`,  `AKAMAI_ACCESS_TOKEN`                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/edgedns)      | | ||||
| | [Epik](https://www.epik.com)                                | `epik`         | `EPIK_SIGNATURE`                                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/epik)         | | ||||
| | [Exoscale](https://www.exoscale.com)                        | `exoscale`     | `EXOSCALE_API_KEY`, `EXOSCALE_API_SECRET`, `EXOSCALE_ENDPOINT`                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/exoscale)     | | ||||
| | [Fast DNS](https://www.akamai.com/)                         | `fastdns`      | `AKAMAI_CLIENT_TOKEN`,  `AKAMAI_CLIENT_SECRET`,  `AKAMAI_ACCESS_TOKEN`                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/edgedns)      | | ||||
| | [Freemyip.com](https://freemyip.com)                        | `freemyip`     | `FREEMYIP_TOKEN`                                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/freemyip)     | | ||||
| | [G-Core Lab](https://gcorelabs.com/dns/)                    | `gcore`        | `GCORE_PERMANENT_API_TOKEN`                                                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/gcore)        | | ||||
| | [Gandi v5](https://doc.livedns.gandi.net)                   | `gandiv5`      | `GANDIV5_API_KEY`                                                                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/gandiv5)      | | ||||
| | [Gandi](https://www.gandi.net)                              | `gandi`        | `GANDI_API_KEY`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/gandi)        | | ||||
| | [Glesys](https://glesys.com/)                               | `glesys`       | `GLESYS_API_USER`, `GLESYS_API_KEY`, `GLESYS_DOMAIN`                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/glesys)       | | ||||
| | [GoDaddy](https://godaddy.com/)                             | `godaddy`      | `GODADDY_API_KEY`, `GODADDY_API_SECRET`                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/godaddy)      | | ||||
| | [Google Cloud DNS](https://cloud.google.com/dns/docs/)      | `gcloud`       | `GCE_PROJECT`, Application Default Credentials [^2] [^3], [`GCE_SERVICE_ACCOUNT_FILE`]                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/gcloud)       | | ||||
| | [Hetzner](https://hetzner.com)                              | `hetzner`      | `HETZNER_API_KEY`                                                                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/hetzner)      | | ||||
| | [hosting.de](https://www.hosting.de)                        | `hostingde`    | `HOSTINGDE_API_KEY`, `HOSTINGDE_ZONE_NAME`                                                                                                  | [Additional configuration](https://go-acme.github.io/lego/dns/hostingde)    | | ||||
| | [Hosttech](https://www.hosttech.eu)                         | `hosttech`     | `HOSTTECH_API_KEY`                                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/hosttech)     | | ||||
| | [HyperOne](https://www.hyperone.com)                        | `hyperone`     | `HYPERONE_PASSPORT_LOCATION`, `HYPERONE_LOCATION_ID`                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/hyperone)     | | ||||
| | [Hurricane Electric](https://dns.he.net)                    | `hurricane`    | `HURRICANE_TOKENS` [^6]                                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/hurricane)    | | ||||
| | [IBM Cloud (SoftLayer)](https://www.ibm.com/cloud/)         | `ibmcloud`     | `SOFTLAYER_USERNAME`, `SOFTLAYER_API_KEY`                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/ibmcloud)     | | ||||
| | [IIJ](https://www.iij.ad.jp/)                               | `iij`          | `IIJ_API_ACCESS_KEY`, `IIJ_API_SECRET_KEY`, `IIJ_DO_SERVICE_CODE`                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/iij)          | | ||||
| | [Infoblox](https://www.infoblox.com/)                       | `infoblox`     | `INFOBLOX_USER`, `INFOBLOX_PASSWORD`, `INFOBLOX_HOST`                                                                                       | [Additional configuration](https://go-acme.github.io/lego/dns/infoblox)     | | ||||
| | [Infomaniak](https://www.infomaniak.com)                    | `infomaniak`   | `INFOMANIAK_ACCESS_TOKEN`                                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/infomaniak)   | | ||||
| | [Internet.bs](https://internetbs.net)                       | `internetbs`   | `INTERNET_BS_API_KEY`, `INTERNET_BS_PASSWORD`                                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/internetbs)   | | ||||
| | [INWX](https://www.inwx.de/en)                              | `inwx`         | `INWX_USERNAME`, `INWX_PASSWORD`                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/inwx)         | | ||||
| | [ionos](https://ionos.com/)                                 | `ionos`        | `IONOS_API_KEY`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/ionos)        | | ||||
| | [Joker.com](https://joker.com)                              | `joker`        | `JOKER_API_MODE` with `JOKER_API_KEY` or `JOKER_USERNAME`, `JOKER_PASSWORD`                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/joker)        | | ||||
| | [Lightsail](https://aws.amazon.com/lightsail/)              | `lightsail`    | `AWS_ACCESS_KEY_ID`, `AWS_SECRET_ACCESS_KEY`, `DNS_ZONE`                                                                                    | [Additional configuration](https://go-acme.github.io/lego/dns/lightsail)    | | ||||
| | [Linode v4](https://www.linode.com)                         | `linode`       | `LINODE_TOKEN`                                                                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/linode)       | | ||||
| | [Liquid Web](https://www.liquidweb.com/)                    | `liquidweb`    | `LIQUID_WEB_PASSWORD`, `LIQUID_WEB_USERNAME`, `LIQUID_WEB_ZONE`                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/liquidweb)    | | ||||
| | [Loopia](https://loopia.com/)                               | `loopia`       | `LOOPIA_API_PASSWORD`, `LOOPIA_API_USER`                                                                                                    | [Additional configuration](https://go-acme.github.io/lego/dns/loopia)       | | ||||
| | [LuaDNS](https://luadns.com)                                | `luadns`       | `LUADNS_API_USERNAME`, `LUADNS_API_TOKEN`                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/luadns)       | | ||||
| | [MyDNS.jp](https://www.mydns.jp/)                           | `mydnsjp`      | `MYDNSJP_MASTER_ID`, `MYDNSJP_PASSWORD`                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/mydnsjp)      | | ||||
| | [Mythic Beasts](https://www.mythic-beasts.com)              | `mythicbeasts` | `MYTHICBEASTS_USER_NAME`, `MYTHICBEASTS_PASSWORD`                                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/mythicbeasts) | | ||||
| | [name.com](https://www.name.com/)                           | `namedotcom`   | `NAMECOM_USERNAME`, `NAMECOM_API_TOKEN`, `NAMECOM_SERVER`                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/namedotcom)   | | ||||
| | [Namecheap](https://www.namecheap.com)                      | `namecheap`    | `NAMECHEAP_API_USER`, `NAMECHEAP_API_KEY`                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/namecheap)    | | ||||
| | [Namesilo](https://www.namesilo.com/)                       | `namesilo`     | `NAMESILO_API_KEY`                                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/namesilo)     | | ||||
| | [Netcup](https://www.netcup.eu/)                            | `netcup`       | `NETCUP_CUSTOMER_NUMBER`, `NETCUP_API_KEY`, `NETCUP_API_PASSWORD`                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/netcup)       | | ||||
| | [Netlify](https://www.netlify.com)                          | `netlify`      | `NETLIFY_TOKEN`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/netlify)      | | ||||
| | [Nicmanager](https://www.nicmanager.com)                    | `nicmanager`   | `NICMANAGER_API_EMAIL`, `NICMANAGER_API_PASSWORD`                                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/nicmanager)   | | ||||
| | [NIFCloud](https://cloud.nifty.com/service/dns.htm)         | `nifcloud`     | `NIFCLOUD_ACCESS_KEY_ID`, `NIFCLOUD_SECRET_ACCESS_KEY`                                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/nifcloud)     | | ||||
| | [Njalla](https://njal.la)                                   | `njalla`       | `NJALLA_TOKEN`                                                                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/njalla)       | | ||||
| | [NS1](https://ns1.com/)                                     | `ns1`          | `NS1_API_KEY`                                                                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/ns1)          | | ||||
| | [Open Telekom Cloud](https://cloud.telekom.de)              | `otc`          | `OTC_DOMAIN_NAME`, `OTC_USER_NAME`, `OTC_PASSWORD`, `OTC_PROJECT_NAME`, `OTC_IDENTITY_ENDPOINT`                                             | [Additional configuration](https://go-acme.github.io/lego/dns/otc)          | | ||||
| | [Openstack Designate](https://docs.openstack.org/designate) | `designate`    | `OS_AUTH_URL`, `OS_USERNAME`, `OS_PASSWORD`, `OS_TENANT_NAME`, `OS_REGION_NAME`                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/designate)    | | ||||
| | [Oracle Cloud](https://cloud.oracle.com/home)               | `oraclecloud`  | `OCI_COMPARTMENT_OCID`, `OCI_PRIVKEY_FILE`, `OCI_PRIVKEY_PASS`, `OCI_PUBKEY_FINGERPRINT`, `OCI_REGION`, `OCI_TENANCY_OCID`, `OCI_USER_OCID` | [Additional configuration](https://go-acme.github.io/lego/dns/oraclecloud)  | | ||||
| | [OVH](https://www.ovh.com)                                  | `ovh`          | `OVH_ENDPOINT`, `OVH_APPLICATION_KEY`, `OVH_APPLICATION_SECRET`, `OVH_CONSUMER_KEY`                                                         | [Additional configuration](https://go-acme.github.io/lego/dns/ovh)          | | ||||
| | [Porkbun](https://porkbun.com/)                             | `porkbun`      | `PORKBUN_SECRET_API_KEY`, `PORKBUN_API_KEY`                                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/porkbun)      | | ||||
| | [PowerDNS](https://www.powerdns.com)                        | `pdns`         | `PDNS_API_KEY`, `PDNS_API_URL`                                                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/pdns)         | | ||||
| | [Rackspace](https://www.rackspace.com/cloud/dns)            | `rackspace`    | `RACKSPACE_USER`, `RACKSPACE_API_KEY`                                                                                                       | [Additional configuration](https://go-acme.github.io/lego/dns/rackspace)    | | ||||
| | [reg.ru](https://www.reg.ru)                                | `regru`        | `REGRU_USERNAME`, `REGRU_PASSWORD`                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/regru)        | | ||||
| | [RFC2136](https://tools.ietf.org/html/rfc2136)              | `rfc2136`      | `RFC2136_TSIG_KEY`, `RFC2136_TSIG_SECRET`, `RFC2136_TSIG_ALGORITHM`, `RFC2136_NAMESERVER`                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/rfc2136)      | | ||||
| | [RimuHosting](https://rimuhosting.com)                      | `rimuhosting`  | `RIMUHOSTING_API_KEY`                                                                                                                       | [Additional configuration](https://go-acme.github.io/lego/dns/rimuhosting)  | | ||||
| | [Route 53](https://aws.amazon.com/route53/)                 | `route53`      | `AWS_ACCESS_KEY_ID`, `AWS_SECRET_ACCESS_KEY`, `[AWS_REGION]`, `[AWS_HOSTED_ZONE_ID]` or a configured user/instance IAM profile.             | [Additional configuration](https://go-acme.github.io/lego/dns/route53)      | | ||||
| | [Sakura Cloud](https://cloud.sakura.ad.jp/)                 | `sakuracloud`  | `SAKURACLOUD_ACCESS_TOKEN`, `SAKURACLOUD_ACCESS_TOKEN_SECRET`                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/sakuracloud)  | | ||||
| | [Scaleway](https://www.scaleway.com)                        | `scaleway`     | `SCALEWAY_API_TOKEN`                                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/scaleway)     | | ||||
| | [Selectel](https://selectel.ru/en/)                         | `selectel`     | `SELECTEL_API_TOKEN`                                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/selectel)     | | ||||
| | [Servercow](https://servercow.de)                           | `servercow`    | `SERVERCOW_USERNAME`, `SERVERCOW_PASSWORD`                                                                                                  | [Additional configuration](https://go-acme.github.io/lego/dns/servercow)    | | ||||
| | [Simply.com](https://www.simply.com/en/domains/)            | `simply`       | `SIMPLY_ACCOUNT_NAME`, `SIMPLY_API_KEY`                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/simply)       | | ||||
| | [Sonic](https://www.sonic.com/)                             | `sonic`        | `SONIC_USER_ID`, `SONIC_API_KEY`                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/sonic)        | | ||||
| | [Stackpath](https://www.stackpath.com/)                     | `stackpath`    | `STACKPATH_CLIENT_ID`, `STACKPATH_CLIENT_SECRET`, `STACKPATH_STACK_ID`                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/stackpath)    | | ||||
| | [Tencent Cloud DNS](https://cloud.tencent.com/product/cns)  | `tencentcloud` | `TENCENTCLOUD_SECRET_ID`, `TENCENTCLOUD_SECRET_KEY`                                                                                         | [Additional configuration](https://go-acme.github.io/lego/dns/tencentcloud) | | ||||
| | [TransIP](https://www.transip.nl/)                          | `transip`      | `TRANSIP_ACCOUNT_NAME`, `TRANSIP_PRIVATE_KEY_PATH`                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/transip)      | | ||||
| | [UKFast SafeDNS](https://www.ukfast.co.uk/dns-hosting.html) | `safedns`      | `SAFEDNS_AUTH_TOKEN`                                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/safedns)      | | ||||
| | [VegaDNS](https://github.com/shupp/VegaDNS-API)             | `vegadns`      | `SECRET_VEGADNS_KEY`, `SECRET_VEGADNS_SECRET`, `VEGADNS_URL`                                                                                | [Additional configuration](https://go-acme.github.io/lego/dns/vegadns)      | | ||||
| | [Versio](https://www.versio.nl/domeinnamen)                 | `versio`       | `VERSIO_USERNAME`, `VERSIO_PASSWORD`                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/versio)       | | ||||
| | [VinylDNS](https://www.vinyldns.io)                         | `vinyldns`     | `VINYLDNS_ACCESS_KEY`, `VINYLDNS_SECRET_KEY`, `VINYLDNS_HOST`                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/vinyldns)     | | ||||
| | [Vscale](https://vscale.io/)                                | `vscale`       | `VSCALE_API_TOKEN`                                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/vscale)       | | ||||
| | [VULTR](https://www.vultr.com)                              | `vultr`        | `VULTR_API_KEY`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/vultr)        | | ||||
| | [WEDOS](https://www.wedos.com)                              | `wedos`        | `WEDOS_USERNAME`, `WEDOS_WAPI_PASSWORD`                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/wedos)        | | ||||
| | [Yandex](https://yandex.com)                                | `yandex`       | `YANDEX_PDD_TOKEN`                                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/yandex)       | | ||||
| | [Zone.ee](https://www.zone.ee)                              | `zoneee`       | `ZONEEE_API_USER`, `ZONEEE_API_KEY`                                                                                                         | [Additional configuration](https://go-acme.github.io/lego/dns/zoneee)       | | ||||
| | [Zonomi](https://zonomi.com)                                | `zonomi`       | `ZONOMI_API_KEY`                                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/zonomi)       | | ||||
| | External Program                                            | `exec`         | `EXEC_PATH`                                                                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/exec)         | | ||||
| | HTTP request                                                | `httpreq`      | `HTTPREQ_ENDPOINT`, `HTTPREQ_MODE`, `HTTPREQ_USERNAME`, `HTTPREQ_PASSWORD` [^1]                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/httpreq)      | | ||||
| | manual                                                      | `manual`       | none, but you need to run Traefik interactively [^4], turn on debug log to see instructions and press <kbd>Enter</kbd>.                     |                                                                             | | ||||
| | Provider Name                                                          | Provider Code      | Environment Variables                                                                                                                       |                                                                                 | | ||||
| |------------------------------------------------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------| | ||||
| | [ACME DNS](https://github.com/joohoi/acme-dns)                         | `acme-dns`         | `ACME_DNS_API_BASE`, `ACME_DNS_STORAGE_PATH`                                                                                                | [Additional configuration](https://go-acme.github.io/lego/dns/acme-dns)         | | ||||
| | [Alibaba Cloud](https://www.alibabacloud.com)                          | `alidns`           | `ALICLOUD_ACCESS_KEY`, `ALICLOUD_SECRET_KEY`, `ALICLOUD_REGION_ID`                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/alidns)           | | ||||
| | [all-inkl](https://all-inkl.com)                                       | `allinkl`          | `ALL_INKL_LOGIN`, `ALL_INKL_PASSWORD`                                                                                                       | [Additional configuration](https://go-acme.github.io/lego/dns/allinkl)          | | ||||
| | [ArvanCloud](https://www.arvancloud.com/en)                            | `arvancloud`       | `ARVANCLOUD_API_KEY`                                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/arvancloud)       | | ||||
| | [Auroradns](https://www.pcextreme.com/dns-health-checks)               | `auroradns`        | `AURORA_USER_ID`, `AURORA_KEY`, `AURORA_ENDPOINT`                                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/auroradns)        | | ||||
| | [Autodns](https://www.internetx.com/domains/autodns/)                  | `autodns`          | `AUTODNS_API_USER`, `AUTODNS_API_PASSWORD`                                                                                                  | [Additional configuration](https://go-acme.github.io/lego/dns/autodns)          | | ||||
| | [Azure](https://azure.microsoft.com/services/dns/)                     | `azure`            | `AZURE_CLIENT_ID`, `AZURE_CLIENT_SECRET`, `AZURE_SUBSCRIPTION_ID`, `AZURE_TENANT_ID`, `AZURE_RESOURCE_GROUP`, `[AZURE_METADATA_ENDPOINT]`   | [Additional configuration](https://go-acme.github.io/lego/dns/azure)            | | ||||
| | [Bindman](https://github.com/labbsr0x/bindman-dns-webhook)             | `bindman`          | `BINDMAN_MANAGER_ADDRESS`                                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/bindman)          | | ||||
| | [Blue Cat](https://www.bluecatnetworks.com/)                           | `bluecat`          | `BLUECAT_SERVER_URL`, `BLUECAT_USER_NAME`, `BLUECAT_PASSWORD`, `BLUECAT_CONFIG_NAME`, `BLUECAT_DNS_VIEW`                                    | [Additional configuration](https://go-acme.github.io/lego/dns/bluecat)          | | ||||
| | [Brandit](https://www.brandit.com)                                     | `brandit`          | `BRANDIT_API_USERNAME`, `BRANDIT_API_KEY`                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/brandit)          | | ||||
| | [Bunny](https://bunny.net)                                             | `bunny`            | `BUNNY_API_KEY`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/bunny)            | | ||||
| | [Checkdomain](https://www.checkdomain.de/)                             | `checkdomain`      | `CHECKDOMAIN_TOKEN`,                                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/checkdomain/)     | | ||||
| | [Civo](https://www.civo.com/)                                          | `civo`             | `CIVO_TOKEN`                                                                                                                                | [Additional configuration](https://go-acme.github.io/lego/dns/civo)             | | ||||
| | [CloudDNS](https://vshosting.eu/)                                      | `clouddns`         | `CLOUDDNS_CLIENT_ID`, `CLOUDDNS_EMAIL`, `CLOUDDNS_PASSWORD`                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/clouddns)         | | ||||
| | [Cloudflare](https://www.cloudflare.com)                               | `cloudflare`       | `CF_API_EMAIL`, `CF_API_KEY` [^5] or `CF_DNS_API_TOKEN`, `[CF_ZONE_API_TOKEN]`                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/cloudflare)       | | ||||
| | [ClouDNS](https://www.cloudns.net/)                                    | `cloudns`          | `CLOUDNS_AUTH_ID`, `CLOUDNS_AUTH_PASSWORD`                                                                                                  | [Additional configuration](https://go-acme.github.io/lego/dns/cloudns)          | | ||||
| | [CloudXNS](https://www.cloudxns.net)                                   | `cloudxns`         | `CLOUDXNS_API_KEY`, `CLOUDXNS_SECRET_KEY`                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/cloudxns)         | | ||||
| | [ConoHa](https://www.conoha.jp)                                        | `conoha`           | `CONOHA_TENANT_ID`, `CONOHA_API_USERNAME`, `CONOHA_API_PASSWORD`                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/conoha)           | | ||||
| | [Constellix](https://constellix.com)                                   | `constellix`       | `CONSTELLIX_API_KEY`, `CONSTELLIX_SECRET_KEY`                                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/constellix)       | | ||||
| | [Derak Cloud](https://derak.cloud/)                                    | `derak`            | `DERAK_API_KEY`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/derak)            | | ||||
| | [deSEC](https://desec.io)                                              | `desec`            | `DESEC_TOKEN`                                                                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/desec)            | | ||||
| | [DigitalOcean](https://www.digitalocean.com)                           | `digitalocean`     | `DO_AUTH_TOKEN`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/digitalocean)     | | ||||
| | [DNS Made Easy](https://dnsmadeeasy.com)                               | `dnsmadeeasy`      | `DNSMADEEASY_API_KEY`, `DNSMADEEASY_API_SECRET`, `DNSMADEEASY_SANDBOX`                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/dnsmadeeasy)      | | ||||
| | [dnsHome.de](https://www.dnshome.de)                                   | `dnsHomede`        | `DNSHOMEDE_CREDENTIALS`                                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/dnshomede)        | | ||||
| | [DNSimple](https://dnsimple.com)                                       | `dnsimple`         | `DNSIMPLE_OAUTH_TOKEN`, `DNSIMPLE_BASE_URL`                                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/dnsimple)         | | ||||
| | [DNSPod](https://www.dnspod.com/)                                      | `dnspod`           | `DNSPOD_API_KEY`                                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/dnspod)           | | ||||
| | [Domain Offensive (do.de)](https://www.do.de/)                         | `dode`             | `DODE_TOKEN`                                                                                                                                | [Additional configuration](https://go-acme.github.io/lego/dns/dode)             | | ||||
| | [Domeneshop](https://domene.shop)                                      | `domeneshop`       | `DOMENESHOP_API_TOKEN`, `DOMENESHOP_API_SECRET`                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/domeneshop)       | | ||||
| | [DreamHost](https://www.dreamhost.com/)                                | `dreamhost`        | `DREAMHOST_API_KEY`                                                                                                                         | [Additional configuration](https://go-acme.github.io/lego/dns/dreamhost)        | | ||||
| | [Duck DNS](https://www.duckdns.org/)                                   | `duckdns`          | `DUCKDNS_TOKEN`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/duckdns)          | | ||||
| | [Dyn](https://dyn.com)                                                 | `dyn`              | `DYN_CUSTOMER_NAME`, `DYN_USER_NAME`, `DYN_PASSWORD`                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/dyn)              | | ||||
| | [Dynu](https://www.dynu.com)                                           | `dynu`             | `DYNU_API_KEY`                                                                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/dynu)             | | ||||
| | [EasyDNS](https://easydns.com/)                                        | `easydns`          | `EASYDNS_TOKEN`, `EASYDNS_KEY`                                                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/easydns)          | | ||||
| | [EdgeDNS](https://www.akamai.com/)                                     | `edgedns`          | `AKAMAI_CLIENT_TOKEN`,  `AKAMAI_CLIENT_SECRET`,  `AKAMAI_ACCESS_TOKEN`                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/edgedns)          | | ||||
| | [Epik](https://www.epik.com)                                           | `epik`             | `EPIK_SIGNATURE`                                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/epik)             | | ||||
| | [Exoscale](https://www.exoscale.com)                                   | `exoscale`         | `EXOSCALE_API_KEY`, `EXOSCALE_API_SECRET`, `EXOSCALE_ENDPOINT`                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/exoscale)         | | ||||
| | [Fast DNS](https://www.akamai.com/)                                    | `fastdns`          | `AKAMAI_CLIENT_TOKEN`,  `AKAMAI_CLIENT_SECRET`,  `AKAMAI_ACCESS_TOKEN`                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/edgedns)          | | ||||
| | [Freemyip.com](https://freemyip.com)                                   | `freemyip`         | `FREEMYIP_TOKEN`                                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/freemyip)         | | ||||
| | [G-Core Lab](https://gcorelabs.com/dns/)                               | `gcore`            | `GCORE_PERMANENT_API_TOKEN`                                                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/gcore)            | | ||||
| | [Gandi v5](https://doc.livedns.gandi.net)                              | `gandiv5`          | `GANDIV5_API_KEY`                                                                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/gandiv5)          | | ||||
| | [Gandi](https://www.gandi.net)                                         | `gandi`            | `GANDI_API_KEY`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/gandi)            | | ||||
| | [Glesys](https://glesys.com/)                                          | `glesys`           | `GLESYS_API_USER`, `GLESYS_API_KEY`, `GLESYS_DOMAIN`                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/glesys)           | | ||||
| | [GoDaddy](https://www.godaddy.com)                                     | `godaddy`          | `GODADDY_API_KEY`, `GODADDY_API_SECRET`                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/godaddy)          | | ||||
| | [Google Domains](https://domains.google)                               | `googledomains`    | `GOOGLE_DOMAINS_ACCESS_TOKEN`                                                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/googledomains)    | | ||||
| | [Google Cloud DNS](https://cloud.google.com/dns/docs/)                 | `gcloud`           | `GCE_PROJECT`, Application Default Credentials [^2] [^3], [`GCE_SERVICE_ACCOUNT_FILE`]                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/gcloud)           | | ||||
| | [Hetzner](https://hetzner.com)                                         | `hetzner`          | `HETZNER_API_KEY`                                                                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/hetzner)          | | ||||
| | [hosting.de](https://www.hosting.de)                                   | `hostingde`        | `HOSTINGDE_API_KEY`, `HOSTINGDE_ZONE_NAME`                                                                                                  | [Additional configuration](https://go-acme.github.io/lego/dns/hostingde)        | | ||||
| | [Hosttech](https://www.hosttech.eu)                                    | `hosttech`         | `HOSTTECH_API_KEY`                                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/hosttech)         | | ||||
| | [Hurricane Electric](https://dns.he.net)                               | `hurricane`        | `HURRICANE_TOKENS` [^6]                                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/hurricane)        | | ||||
| | [HyperOne](https://www.hyperone.com)                                   | `hyperone`         | `HYPERONE_PASSPORT_LOCATION`, `HYPERONE_LOCATION_ID`                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/hyperone)         | | ||||
| | [IBM Cloud (SoftLayer)](https://www.ibm.com/cloud/)                    | `ibmcloud`         | `SOFTLAYER_USERNAME`, `SOFTLAYER_API_KEY`                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/ibmcloud)         | | ||||
| | [IIJ DNS Platform Service](https://www.iij.ad.jp)                      | `iijdpf`           | `IIJ_DPF_API_TOKEN` , `IIJ_DPF_DPM_SERVICE_CODE`                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/iijdpf)           | | ||||
| | [IIJ](https://www.iij.ad.jp/)                                          | `iij`              | `IIJ_API_ACCESS_KEY`, `IIJ_API_SECRET_KEY`, `IIJ_DO_SERVICE_CODE`                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/iij)              | | ||||
| | [Infoblox](https://www.infoblox.com/)                                  | `infoblox`         | `INFOBLOX_USERNAME`, `INFOBLOX_PASSWORD`, `INFOBLOX_HOST`                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/infoblox)         | | ||||
| | [Infomaniak](https://www.infomaniak.com)                               | `infomaniak`       | `INFOMANIAK_ACCESS_TOKEN`                                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/infomaniak)       | | ||||
| | [Internet.bs](https://internetbs.net)                                  | `internetbs`       | `INTERNET_BS_API_KEY`, `INTERNET_BS_PASSWORD`                                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/internetbs)       | | ||||
| | [INWX](https://www.inwx.de/en)                                         | `inwx`             | `INWX_USERNAME`, `INWX_PASSWORD`                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/inwx)             | | ||||
| | [ionos](https://ionos.com/)                                            | `ionos`            | `IONOS_API_KEY`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/ionos)            | | ||||
| | [iwantmyname](https://iwantmyname.com)                                 | `iwantmyname`      | `IWANTMYNAME_USERNAME` , `IWANTMYNAME_PASSWORD`                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/iwantmyname)      | | ||||
| | [Joker.com](https://joker.com)                                         | `joker`            | `JOKER_API_MODE` with `JOKER_API_KEY` or `JOKER_USERNAME`, `JOKER_PASSWORD`                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/joker)            | | ||||
| | [Liara](https://liara.ir)                                              | `liara`            | `LIARA_API_KEY`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/liara)            | | ||||
| | [Lightsail](https://aws.amazon.com/lightsail/)                         | `lightsail`        | `AWS_ACCESS_KEY_ID`, `AWS_SECRET_ACCESS_KEY`, `DNS_ZONE`                                                                                    | [Additional configuration](https://go-acme.github.io/lego/dns/lightsail)        | | ||||
| | [Linode v4](https://www.linode.com)                                    | `linode`           | `LINODE_TOKEN`                                                                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/linode)           | | ||||
| | [Liquid Web](https://www.liquidweb.com/)                               | `liquidweb`        | `LIQUID_WEB_PASSWORD`, `LIQUID_WEB_USERNAME`, `LIQUID_WEB_ZONE`                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/liquidweb)        | | ||||
| | [Loopia](https://loopia.com/)                                          | `loopia`           | `LOOPIA_API_PASSWORD`, `LOOPIA_API_USER`                                                                                                    | [Additional configuration](https://go-acme.github.io/lego/dns/loopia)           | | ||||
| | [LuaDNS](https://luadns.com)                                           | `luadns`           | `LUADNS_API_USERNAME`, `LUADNS_API_TOKEN`                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/luadns)           | | ||||
| | [MyDNS.jp](https://www.mydns.jp/)                                      | `mydnsjp`          | `MYDNSJP_MASTER_ID`, `MYDNSJP_PASSWORD`                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/mydnsjp)          | | ||||
| | [Mythic Beasts](https://www.mythic-beasts.com)                         | `mythicbeasts`     | `MYTHICBEASTS_USER_NAME`, `MYTHICBEASTS_PASSWORD`                                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/mythicbeasts)     | | ||||
| | [name.com](https://www.name.com/)                                      | `namedotcom`       | `NAMECOM_USERNAME`, `NAMECOM_API_TOKEN`, `NAMECOM_SERVER`                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/namedotcom)       | | ||||
| | [Namecheap](https://www.namecheap.com)                                 | `namecheap`        | `NAMECHEAP_API_USER`, `NAMECHEAP_API_KEY`                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/namecheap)        | | ||||
| | [Namesilo](https://www.namesilo.com/)                                  | `namesilo`         | `NAMESILO_API_KEY`                                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/namesilo)         | | ||||
| | [NearlyFreeSpeech.NET](https://www.nearlyfreespeech.net/)              | `nearlyfreespeech` | `NEARLYFREESPEECH_API_KEY`, `NEARLYFREESPEECH_LOGIN`                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/nearlyfreespeech) | | ||||
| | [Netcup](https://www.netcup.eu/)                                       | `netcup`           | `NETCUP_CUSTOMER_NUMBER`, `NETCUP_API_KEY`, `NETCUP_API_PASSWORD`                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/netcup)           | | ||||
| | [Netlify](https://www.netlify.com)                                     | `netlify`          | `NETLIFY_TOKEN`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/netlify)          | | ||||
| | [Nicmanager](https://www.nicmanager.com)                               | `nicmanager`       | `NICMANAGER_API_EMAIL`, `NICMANAGER_API_PASSWORD`                                                                                           | [Additional configuration](https://go-acme.github.io/lego/dns/nicmanager)       | | ||||
| | [NIFCloud](https://cloud.nifty.com/service/dns.htm)                    | `nifcloud`         | `NIFCLOUD_ACCESS_KEY_ID`, `NIFCLOUD_SECRET_ACCESS_KEY`                                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/nifcloud)         | | ||||
| | [Njalla](https://njal.la)                                              | `njalla`           | `NJALLA_TOKEN`                                                                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/njalla)           | | ||||
| | [Nodion](https://www.nodion.com)                                       | `nodion`           | `NODION_API_TOKEN`                                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/nodion)           | | ||||
| | [NS1](https://ns1.com/)                                                | `ns1`              | `NS1_API_KEY`                                                                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/ns1)              | | ||||
| | [Open Telekom Cloud](https://cloud.telekom.de)                         | `otc`              | `OTC_DOMAIN_NAME`, `OTC_USER_NAME`, `OTC_PASSWORD`, `OTC_PROJECT_NAME`, `OTC_IDENTITY_ENDPOINT`                                             | [Additional configuration](https://go-acme.github.io/lego/dns/otc)              | | ||||
| | [Openstack Designate](https://docs.openstack.org/designate)            | `designate`        | `OS_AUTH_URL`, `OS_USERNAME`, `OS_PASSWORD`, `OS_TENANT_NAME`, `OS_REGION_NAME`                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/designate)        | | ||||
| | [Oracle Cloud](https://cloud.oracle.com/home)                          | `oraclecloud`      | `OCI_COMPARTMENT_OCID`, `OCI_PRIVKEY_FILE`, `OCI_PRIVKEY_PASS`, `OCI_PUBKEY_FINGERPRINT`, `OCI_REGION`, `OCI_TENANCY_OCID`, `OCI_USER_OCID` | [Additional configuration](https://go-acme.github.io/lego/dns/oraclecloud)      | | ||||
| | [OVH](https://www.ovh.com)                                             | `ovh`              | `OVH_ENDPOINT`, `OVH_APPLICATION_KEY`, `OVH_APPLICATION_SECRET`, `OVH_CONSUMER_KEY`                                                         | [Additional configuration](https://go-acme.github.io/lego/dns/ovh)              | | ||||
| | [Plesk](https://www.plesk.com)                                         | `plesk`            | `PLESK_SERVER_BASE_URL`, `PLESK_USERNAME`, `PLESK_PASSWORD`                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/plesk)            | | ||||
| | [Porkbun](https://porkbun.com/)                                        | `porkbun`          | `PORKBUN_SECRET_API_KEY`, `PORKBUN_API_KEY`                                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/porkbun)          | | ||||
| | [PowerDNS](https://www.powerdns.com)                                   | `pdns`             | `PDNS_API_KEY`, `PDNS_API_URL`                                                                                                              | [Additional configuration](https://go-acme.github.io/lego/dns/pdns)             | | ||||
| | [Rackspace](https://www.rackspace.com/cloud/dns)                       | `rackspace`        | `RACKSPACE_USER`, `RACKSPACE_API_KEY`                                                                                                       | [Additional configuration](https://go-acme.github.io/lego/dns/rackspace)        | | ||||
| | [reg.ru](https://www.reg.ru)                                           | `regru`            | `REGRU_USERNAME`, `REGRU_PASSWORD`                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/regru)            | | ||||
| | [RFC2136](https://tools.ietf.org/html/rfc2136)                         | `rfc2136`          | `RFC2136_TSIG_KEY`, `RFC2136_TSIG_SECRET`, `RFC2136_TSIG_ALGORITHM`, `RFC2136_NAMESERVER`                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/rfc2136)          | | ||||
| | [RimuHosting](https://rimuhosting.com)                                 | `rimuhosting`      | `RIMUHOSTING_API_KEY`                                                                                                                       | [Additional configuration](https://go-acme.github.io/lego/dns/rimuhosting)      | | ||||
| | [Route 53](https://aws.amazon.com/route53/)                            | `route53`          | `AWS_ACCESS_KEY_ID`, `AWS_SECRET_ACCESS_KEY`, `[AWS_REGION]`, `[AWS_HOSTED_ZONE_ID]` or a configured user/instance IAM profile.             | [Additional configuration](https://go-acme.github.io/lego/dns/route53)          | | ||||
| | [Sakura Cloud](https://cloud.sakura.ad.jp/)                            | `sakuracloud`      | `SAKURACLOUD_ACCESS_TOKEN`, `SAKURACLOUD_ACCESS_TOKEN_SECRET`                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/sakuracloud)      | | ||||
| | [Scaleway](https://www.scaleway.com)                                   | `scaleway`         | `SCALEWAY_API_TOKEN`                                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/scaleway)         | | ||||
| | [Selectel](https://selectel.ru/en/)                                    | `selectel`         | `SELECTEL_API_TOKEN`                                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/selectel)         | | ||||
| | [Servercow](https://servercow.de)                                      | `servercow`        | `SERVERCOW_USERNAME`, `SERVERCOW_PASSWORD`                                                                                                  | [Additional configuration](https://go-acme.github.io/lego/dns/servercow)        | | ||||
| | [Simply.com](https://www.simply.com/en/domains/)                       | `simply`           | `SIMPLY_ACCOUNT_NAME`, `SIMPLY_API_KEY`                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/simply)           | | ||||
| | [Sonic](https://www.sonic.com/)                                        | `sonic`            | `SONIC_USER_ID`, `SONIC_API_KEY`                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/sonic)            | | ||||
| | [Stackpath](https://www.stackpath.com/)                                | `stackpath`        | `STACKPATH_CLIENT_ID`, `STACKPATH_CLIENT_SECRET`, `STACKPATH_STACK_ID`                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/stackpath)        | | ||||
| | [Tencent Cloud DNS](https://cloud.tencent.com/product/cns)             | `tencentcloud`     | `TENCENTCLOUD_SECRET_ID`, `TENCENTCLOUD_SECRET_KEY`                                                                                         | [Additional configuration](https://go-acme.github.io/lego/dns/tencentcloud)     | | ||||
| | [TransIP](https://www.transip.nl/)                                     | `transip`          | `TRANSIP_ACCOUNT_NAME`, `TRANSIP_PRIVATE_KEY_PATH`                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/transip)          | | ||||
| | [UKFast SafeDNS](https://docs.ukfast.co.uk/domains/safedns/index.html) | `safedns`          | `SAFEDNS_AUTH_TOKEN`                                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/safedns)          | | ||||
| | [Ultradns](https://neustarsecurityservices.com/dns-services)           | `ultradns`         | `ULTRADNS_USERNAME`, `ULTRADNS_PASSWORD`                                                                                                    | [Additional configuration](https://go-acme.github.io/lego/dns/ultradns)         | | ||||
| | [Variomedia](https://www.variomedia.de/)                               | `variomedia`       | `VARIOMEDIA_API_TOKEN`                                                                                                                      | [Additional configuration](https://go-acme.github.io/lego/dns/variomedia)       | | ||||
| | [VegaDNS](https://github.com/shupp/VegaDNS-API)                        | `vegadns`          | `SECRET_VEGADNS_KEY`, `SECRET_VEGADNS_SECRET`, `VEGADNS_URL`                                                                                | [Additional configuration](https://go-acme.github.io/lego/dns/vegadns)          | | ||||
| | [Vercel](https://vercel.com)                                           | `vercel`           | `VERCEL_API_TOKEN`                                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/vercel)           | | ||||
| | [Versio](https://www.versio.nl/domeinnamen)                            | `versio`           | `VERSIO_USERNAME`, `VERSIO_PASSWORD`                                                                                                        | [Additional configuration](https://go-acme.github.io/lego/dns/versio)           | | ||||
| | [VinylDNS](https://www.vinyldns.io)                                    | `vinyldns`         | `VINYLDNS_ACCESS_KEY`, `VINYLDNS_SECRET_KEY`, `VINYLDNS_HOST`                                                                               | [Additional configuration](https://go-acme.github.io/lego/dns/vinyldns)         | | ||||
| | [VK Cloud](https://mcs.mail.ru/)                                       | `vkcloud`          | `VK_CLOUD_PASSWORD`, `VK_CLOUD_PROJECT_ID`, `VK_CLOUD_USERNAME`                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/vkcloud)          | | ||||
| | [Vscale](https://vscale.io/)                                           | `vscale`           | `VSCALE_API_TOKEN`                                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/vscale)           | | ||||
| | [VULTR](https://www.vultr.com)                                         | `vultr`            | `VULTR_API_KEY`                                                                                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/vultr)            | | ||||
| | [Websupport](https://websupport.sk)                                    | `websupport`       | `WEBSUPPORT_API_KEY`, `WEBSUPPORT_SECRET`                                                                                                   | [Additional configuration](https://go-acme.github.io/lego/dns/websupport)       | | ||||
| | [WEDOS](https://www.wedos.com)                                         | `wedos`            | `WEDOS_USERNAME`, `WEDOS_WAPI_PASSWORD`                                                                                                     | [Additional configuration](https://go-acme.github.io/lego/dns/wedos)            | | ||||
| | [Yandex Cloud](https://cloud.yandex.com/en/)                           | `yandexcloud`      | `YANDEX_CLOUD_FOLDER_ID`, `YANDEX_CLOUD_IAM_TOKEN`                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/yandexcloud)      | | ||||
| | [Yandex](https://yandex.com)                                           | `yandex`           | `YANDEX_PDD_TOKEN`                                                                                                                          | [Additional configuration](https://go-acme.github.io/lego/dns/yandex)           | | ||||
| | [Zone.ee](https://www.zone.ee)                                         | `zoneee`           | `ZONEEE_API_USER`, `ZONEEE_API_KEY`                                                                                                         | [Additional configuration](https://go-acme.github.io/lego/dns/zoneee)           | | ||||
| | [Zonomi](https://zonomi.com)                                           | `zonomi`           | `ZONOMI_API_KEY`                                                                                                                            | [Additional configuration](https://go-acme.github.io/lego/dns/zonomi)           | | ||||
| | External Program                                                       | `exec`             | `EXEC_PATH`                                                                                                                                 | [Additional configuration](https://go-acme.github.io/lego/dns/exec)             | | ||||
| | HTTP request                                                           | `httpreq`          | `HTTPREQ_ENDPOINT`, `HTTPREQ_MODE`, `HTTPREQ_USERNAME`, `HTTPREQ_PASSWORD` [^1]                                                             | [Additional configuration](https://go-acme.github.io/lego/dns/httpreq)          | | ||||
| | manual                                                                 | `manual`           | none, but you need to run Traefik interactively [^4], turn on debug log to see instructions and press <kbd>Enter</kbd>.                     |                                                                                 | | ||||
|  | ||||
| [^1]: More information about the HTTP message format can be found [here](https://go-acme.github.io/lego/dns/httpreq/). | ||||
| [^2]: [Providing credentials to your application](https://cloud.google.com/docs/authentication/production). | ||||
| @@ -658,8 +691,10 @@ certificatesResolvers: | ||||
| If Let's Encrypt is not reachable, the following certificates will apply: | ||||
|  | ||||
|   1. Previously generated ACME certificates (before downtime) | ||||
|   1. Expired ACME certificates | ||||
|   1. Provided certificates | ||||
|   2. Expired ACME certificates | ||||
|   3. Provided certificates | ||||
|  | ||||
| !!! important | ||||
|     For new (sub)domains which need Let's Encrypt authentication, the default Traefik certificate will be used until Traefik is restarted. | ||||
|  | ||||
| {!traefik-for-business-applications.md!} | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| ## Dynamic configuration | ||||
| labels: | ||||
|   - traefik.http.routers.blog.rule=Host(`example.com`) && Path(`/blog`) | ||||
| @@ -22,7 +22,7 @@ deploy: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: IngressRoute | ||||
| metadata: | ||||
|   name: blogtls | ||||
| @@ -43,27 +43,6 @@ spec: | ||||
|       - '*.example.org' | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| labels: { | ||||
|   "traefik.http.routers.blog.rule": "Host(`example.com`) && Path(`/blog`)", | ||||
|   "traefik.http.routers.blog.tls": "true", | ||||
|   "traefik.http.routers.blog.tls.certresolver": "myresolver", | ||||
|   "traefik.http.routers.blog.tls.domains[0].main": "example.com", | ||||
|   "traefik.http.routers.blog.tls.domains[0].sans": "*.example.com", | ||||
|   "traefik.http.services.blog-svc.loadbalancer.server.port": "8080" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| ## Dynamic configuration | ||||
| labels: | ||||
|   - traefik.http.routers.blog.rule=Host(`example.com`) && Path(`/blog`) | ||||
|   - traefik.http.routers.blog.tls=true | ||||
|   - traefik.http.routers.blog.tls.certresolver=myresolver | ||||
|   - traefik.http.routers.blog.tls.domains[0].main=example.org | ||||
|   - traefik.http.routers.blog.tls.domains[0].sans=*.example.org | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| ## Dynamic configuration | ||||
| http: | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| ## Dynamic configuration | ||||
| labels: | ||||
|   - traefik.http.routers.blog.rule=(Host(`example.com`) && Path(`/blog`)) || Host(`blog.example.org`) | ||||
| @@ -18,7 +18,7 @@ deploy: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: IngressRoute | ||||
| metadata: | ||||
|   name: blogtls | ||||
| @@ -35,23 +35,6 @@ spec: | ||||
|     certResolver: myresolver | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| labels: { | ||||
|   "traefik.http.routers.blog.rule": "(Host(`example.com`) && Path(`/blog`)) || Host(`blog.example.org`)", | ||||
|   "traefik.http.routers.blog.tls": "true", | ||||
|   "traefik.http.routers.blog.tls.certresolver": "myresolver", | ||||
|   "traefik.http.services.blog-svc.loadbalancer.server.port": "8080" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| ## Dynamic configuration | ||||
| labels: | ||||
|   - traefik.http.routers.blog.rule=(Host(`example.com`) && Path(`/blog`)) || Host(`blog.example.org`) | ||||
|   - traefik.http.routers.blog.tls=true | ||||
|   - traefik.http.routers.blog.tls.certresolver=myresolver | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| ## Dynamic configuration | ||||
| http: | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| ## Dynamic configuration | ||||
| labels: | ||||
|   - traefik.http.routers.blog.rule=Host(`example.com`) && Path(`/blog`) | ||||
| @@ -18,7 +18,7 @@ deploy: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: IngressRoute | ||||
| metadata: | ||||
|   name: blogtls | ||||
| @@ -35,23 +35,6 @@ spec: | ||||
|     certResolver: myresolver | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| labels: { | ||||
|   "traefik.http.routers.blog.rule": "Host(`example.com`) && Path(`/blog`)", | ||||
|   "traefik.http.routers.blog.tls": "true", | ||||
|   "traefik.http.routers.blog.tls.certresolver": "myresolver", | ||||
|   "traefik.http.services.blog-svc.loadbalancer.server.port": "8080" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| ## Dynamic configuration | ||||
| labels: | ||||
|   - traefik.http.routers.blog.rule=Host(`example.com`) && Path(`/blog`) | ||||
|   - traefik.http.routers.blog.tls=true | ||||
|   - traefik.http.routers.blog.tls.certresolver=myresolver | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| ## Dynamic configuration | ||||
| http: | ||||
|   | ||||
| @@ -19,3 +19,5 @@ The next sections of this documentation explain how to configure the TLS connect | ||||
| That is to say, how to obtain [TLS certificates](./tls.md#certificates-definition): | ||||
| either through a definition in the dynamic configuration, or through [Let's Encrypt](./acme.md) (ACME). | ||||
| And how to configure [TLS options](./tls.md#tls-options), and [certificates stores](./tls.md#certificates-stores). | ||||
|  | ||||
| {!traefik-for-business-applications.md!} | ||||
|   | ||||
							
								
								
									
										56
									
								
								docs/content/https/spiffe.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								docs/content/https/spiffe.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | ||||
| --- | ||||
| title: "Traefik SPIFFE Documentation" | ||||
| description: "Learn how to configure Traefik to use SPIFFE. Read the technical documentation." | ||||
| --- | ||||
|  | ||||
| # SPIFFE | ||||
|  | ||||
| Secure the backend connection with SPIFFE. | ||||
| {: .subtitle } | ||||
|  | ||||
| [SPIFFE](https://spiffe.io/docs/latest/spiffe-about/overview/) (Secure Production Identity Framework For Everyone),  | ||||
| provides a secure identity in the form of a specially crafted X.509 certificate,  | ||||
| to every workload in an environment. | ||||
|  | ||||
| Traefik is able to connect to the Workload API to obtain an x509-SVID used to secure the connection with SPIFFE enabled backends. | ||||
|  | ||||
| ## Configuration | ||||
|  | ||||
| ### General | ||||
|  | ||||
| Enabling SPIFFE is part of the [static configuration](../getting-started/configuration-overview.md#the-static-configuration). | ||||
| It can be defined by using a file (YAML or TOML) or CLI arguments. | ||||
|  | ||||
| ### Workload API | ||||
|  | ||||
| The `workloadAPIAddr` configuration defines the address of the SPIFFE [Workload API](https://spiffe.io/docs/latest/spiffe-about/spiffe-concepts/#spiffe-workload-api). | ||||
|  | ||||
| !!! info "Enabling SPIFFE in ServersTransports" | ||||
|  | ||||
|     Enabling SPIFFE does not imply that backend connections are going to use it automatically. | ||||
|     Each [ServersTransport](../routing/services/index.md#serverstransport_1) or [TCPServersTransport](../routing/services/index.md#serverstransport_2), | ||||
| 	that is meant to be secured with SPIFFE, | ||||
| 	must explicitly enable it (see [SPIFFE with ServersTransport](../routing/services/index.md#spiffe) or [SPIFFE with TCPServersTransport](../routing/services/index.md#spiffe_1)). | ||||
|  | ||||
| !!! warning "SPIFFE can cause Traefik to stall" | ||||
| 	When using SPIFFE, | ||||
| 	Traefik will wait for the first SVID to be delivered before starting. | ||||
| 	If Traefik is hanging when waiting on SPIFFE SVID delivery, | ||||
| 	please double check that it is correctly registered as workload in your SPIFFE infrastructure. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| ## Static configuration | ||||
| spiffe: | ||||
|     workloadAPIAddr: localhost | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| ## Static configuration | ||||
| [spiffe] | ||||
|     workloadAPIAddr: localhost | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| ## Static configuration | ||||
| --spiffe.workloadAPIAddr=localhost | ||||
| ``` | ||||
							
								
								
									
										207
									
								
								docs/content/https/tailscale.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										207
									
								
								docs/content/https/tailscale.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,207 @@ | ||||
| --- | ||||
| title: "Traefik Tailscale Documentation" | ||||
| description: "Learn how to configure Traefik Proxy to resolve TLS certificates for your Tailscale services. Read the technical documentation." | ||||
| --- | ||||
|  | ||||
| # Tailscale | ||||
|  | ||||
| Provision TLS certificates for your internal Tailscale services. | ||||
| {: .subtitle } | ||||
|  | ||||
| To protect a service with TLS, a certificate from a public Certificate Authority is needed. | ||||
| In addition to its vpn role, Tailscale can also [provide certificates](https://tailscale.com/kb/1153/enabling-https/) for the machines in your Tailscale network. | ||||
|  | ||||
| ## Certificate resolvers | ||||
|  | ||||
| To obtain a TLS certificate from the Tailscale daemon, | ||||
| a Tailscale certificate resolver needs to be configured as below. | ||||
|  | ||||
| !!! info "Referencing a certificate resolver" | ||||
|  | ||||
|     Defining a certificate resolver does not imply that routers are going to use it automatically. | ||||
|     Each router or entrypoint that is meant to use the resolver must explicitly [reference](../routing/routers/index.md#certresolver) it. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| certificatesResolvers: | ||||
|     myresolver: | ||||
|         tailscale: {} | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [certificatesResolvers.myresolver.tailscale] | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --certificatesresolvers.myresolver.tailscale=true | ||||
| ``` | ||||
|  | ||||
| ## Domain Definition | ||||
|  | ||||
| A certificate resolver requests certificates for a set of domain names inferred from routers, according to the following: | ||||
|  | ||||
| - If the router has a [`tls.domains`](../routing/routers/index.md#domains) option set, | ||||
|   then the certificate resolver derives this router domain name from the `main` option of `tls.domains`. | ||||
|  | ||||
| - Otherwise, the certificate resolver derives the domain name from any `Host()` or `HostSNI()` matchers | ||||
|   in the [router's rule](../routing/routers/index.md#rule). | ||||
|  | ||||
| !!! info "Tailscale Domain Format" | ||||
|  | ||||
|     The domain is only taken into account if it is a Tailscale-specific one, | ||||
|     i.e. of the form `machine-name.domains-alias.ts.net`. | ||||
|  | ||||
| ## Configuration Example | ||||
|  | ||||
| !!! example "Enabling Tailscale certificate resolution" | ||||
|  | ||||
|     ```yaml tab="File (YAML)" | ||||
|     entryPoints: | ||||
|       web: | ||||
|         address: ":80" | ||||
|  | ||||
|       websecure: | ||||
|         address: ":443" | ||||
|  | ||||
|     certificatesResolvers: | ||||
|       myresolver: | ||||
|         tailscale: {} | ||||
|     ``` | ||||
|  | ||||
|     ```toml tab="File (TOML)" | ||||
|     [entryPoints] | ||||
|       [entryPoints.web] | ||||
|         address = ":80" | ||||
|  | ||||
|       [entryPoints.websecure] | ||||
|         address = ":443" | ||||
|  | ||||
|     [certificatesResolvers.myresolver.tailscale] | ||||
|     ``` | ||||
|  | ||||
|     ```bash tab="CLI" | ||||
|     --entrypoints.web.address=:80 | ||||
|     --entrypoints.websecure.address=:443 | ||||
|     # ... | ||||
|     --certificatesresolvers.myresolver.tailscale=true | ||||
|     ``` | ||||
|  | ||||
| !!! example "Domain from Router's Rule Example" | ||||
|  | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     ## Dynamic configuration | ||||
|     labels: | ||||
|       - traefik.http.routers.blog.rule=Host(`monitoring.yak-bebop.ts.net`) && Path(`/metrics`) | ||||
|       - traefik.http.routers.blog.tls.certresolver=myresolver | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="Docker (Swarm)" | ||||
|     ## Dynamic configuration | ||||
|     deploy: | ||||
|       labels: | ||||
|         - traefik.http.routers.blog.rule=Host(`monitoring.yak-bebop.ts.net`) && Path(`/metrics`) | ||||
|         - traefik.http.routers.blog.tls.certresolver=myresolver | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="Kubernetes" | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: IngressRoute | ||||
|     metadata: | ||||
|       name: blogtls | ||||
|     spec: | ||||
|       entryPoints: | ||||
|         - websecure | ||||
|       routes: | ||||
|         - match: Host(`monitoring.yak-bebop.ts.net`) && Path(`/metrics`) | ||||
|           kind: Rule | ||||
|           services: | ||||
|             - name: blog | ||||
|               port: 8080 | ||||
|       tls: | ||||
|         certResolver: myresolver | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="File (YAML)" | ||||
|     ## Dynamic configuration | ||||
|     http: | ||||
|       routers: | ||||
|         blog: | ||||
|           rule: "Host(`monitoring.yak-bebop.ts.net`) && Path(`/metrics`)" | ||||
|           tls: | ||||
|             certResolver: myresolver | ||||
|     ``` | ||||
|  | ||||
|     ```toml tab="File (TOML)" | ||||
|     ## Dynamic configuration | ||||
|     [http.routers] | ||||
|       [http.routers.blog] | ||||
|       rule = "Host(`monitoring.yak-bebop.ts.net`) && Path(`/metrics`)" | ||||
|       [http.routers.blog.tls] | ||||
|         certResolver = "myresolver" | ||||
|     ``` | ||||
|  | ||||
| !!! example "Domain from Router's tls.domain Example" | ||||
|  | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     ## Dynamic configuration | ||||
|     labels: | ||||
|       - traefik.http.routers.blog.rule=Path(`/metrics`) | ||||
|       - traefik.http.routers.blog.tls.certresolver=myresolver | ||||
|       - traefik.http.routers.blog.tls.domains[0].main=monitoring.yak-bebop.ts.net | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="Docker (Swarm)" | ||||
|     ## Dynamic configuration | ||||
|     deploy: | ||||
|       labels: | ||||
|         - traefik.http.routers.blog.rule=Path(`/metrics`) | ||||
|         - traefik.http.routers.blog.tls.certresolver=myresolver | ||||
|         - traefik.http.routers.blog.tls.domains[0].main=monitoring.yak-bebop.ts.net | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="Kubernetes" | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: IngressRoute | ||||
|     metadata: | ||||
|       name: blogtls | ||||
|     spec: | ||||
|       entryPoints: | ||||
|         - websecure | ||||
|       routes: | ||||
|         - match: Path(`/metrics`) | ||||
|           kind: Rule | ||||
|           services: | ||||
|             - name: blog | ||||
|               port: 8080 | ||||
|       tls: | ||||
|         certResolver: myresolver | ||||
|         domains: | ||||
|           - main: monitoring.yak-bebop.ts.net | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="File (YAML)" | ||||
|     ## Dynamic configuration | ||||
|     http: | ||||
|       routers: | ||||
|         blog: | ||||
|           rule: "Path(`/metrics`)" | ||||
|           tls: | ||||
|             certResolver: myresolver | ||||
|             domains: | ||||
|               - main: "monitoring.yak-bebop.ts.net" | ||||
|     ``` | ||||
|  | ||||
|     ```toml tab="File (TOML)" | ||||
|     ## Dynamic configuration | ||||
|     [http.routers] | ||||
|       [http.routers.blog] | ||||
|         rule = "Path(`/metrics`)" | ||||
|         [http.routers.blog.tls] | ||||
|           certResolver = "myresolver" | ||||
|           [[http.routers.blog.tls.domains]] | ||||
|             main = "monitoring.yak-bebop.ts.net" | ||||
|     ``` | ||||
|  | ||||
| ## Automatic Renewals | ||||
|  | ||||
| Traefik automatically tracks the expiry date of each Tailscale certificate it fetches, | ||||
| and starts to renew a certificate 14 days before its expiry to match Tailscale daemon renew policy. | ||||
| @@ -134,7 +134,7 @@ tls: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSStore | ||||
| metadata: | ||||
|   name: default | ||||
| @@ -157,7 +157,67 @@ data: | ||||
|   tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0= | ||||
| ``` | ||||
|  | ||||
| If no default certificate is provided, Traefik generates and uses a self-signed certificate. | ||||
| If no `defaultCertificate` is provided, Traefik will use the generated one. | ||||
|  | ||||
| ### ACME Default Certificate | ||||
|  | ||||
| You can configure Traefik to use an ACME provider (like Let's Encrypt) to generate the default certificate. | ||||
| The configuration to resolve the default certificate should be defined in a TLS store: | ||||
|  | ||||
| !!! important "Precedence with the `defaultGeneratedCert` option" | ||||
|  | ||||
|     The `defaultGeneratedCert` definition takes precedence over the ACME default certificate configuration. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Dynamic configuration | ||||
|  | ||||
| tls: | ||||
|   stores: | ||||
|     default: | ||||
|       defaultGeneratedCert: | ||||
|         resolver: myresolver | ||||
|         domain: | ||||
|           main: example.org | ||||
|           sans: | ||||
|             - foo.example.org | ||||
|             - bar.example.org | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| # Dynamic configuration | ||||
|  | ||||
| [tls.stores] | ||||
|   [tls.stores.default.defaultGeneratedCert] | ||||
|     resolver = "myresolver" | ||||
|     [tls.stores.default.defaultGeneratedCert.domain] | ||||
|       main = "example.org" | ||||
|       sans = ["foo.example.org", "bar.example.org"] | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSStore | ||||
| metadata: | ||||
|   name: default | ||||
|   namespace: default | ||||
|  | ||||
| spec: | ||||
|   defaultGeneratedCert: | ||||
|     resolver: myresolver | ||||
|     domain: | ||||
|       main: example.org | ||||
|       sans: | ||||
|         - foo.example.org | ||||
|         - bar.example.org | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Docker & Swarm" | ||||
| ## Dynamic configuration | ||||
| labels: | ||||
|   - "traefik.tls.stores.default.defaultgeneratedcert.resolver=myresolver" | ||||
|   - "traefik.tls.stores.default.defaultgeneratedcert.domain.main=example.org" | ||||
|   - "traefik.tls.stores.default.defaultgeneratedcert.domain.sans=foo.example.org, bar.example.org" | ||||
| ``` | ||||
|  | ||||
| ## TLS Options | ||||
|  | ||||
| @@ -209,7 +269,7 @@ tls: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSOption | ||||
| metadata: | ||||
|   name: default | ||||
| @@ -219,7 +279,7 @@ spec: | ||||
|   minVersion: VersionTLS12 | ||||
|  | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSOption | ||||
| metadata: | ||||
|   name: mintls13 | ||||
| @@ -260,7 +320,7 @@ tls: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSOption | ||||
| metadata: | ||||
|   name: default | ||||
| @@ -270,7 +330,7 @@ spec: | ||||
|   maxVersion: VersionTLS13 | ||||
|  | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSOption | ||||
| metadata: | ||||
|   name: maxtls12 | ||||
| @@ -305,7 +365,7 @@ tls: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSOption | ||||
| metadata: | ||||
|   name: default | ||||
| @@ -350,7 +410,7 @@ tls: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSOption | ||||
| metadata: | ||||
|   name: default | ||||
| @@ -364,8 +424,9 @@ spec: | ||||
|  | ||||
| ### Strict SNI Checking | ||||
|  | ||||
| With strict SNI checking enabled, Traefik won't allow connections from clients | ||||
| that do not specify a server_name extension or don't match any certificate configured on the tlsOption. | ||||
| With strict SNI checking enabled, Traefik won't allow connections from clients that do not specify a server_name extension | ||||
| or don't match any of the configured certificates. | ||||
| The default certificate is irrelevant on that matter. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Dynamic configuration | ||||
| @@ -385,7 +446,7 @@ tls: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSOption | ||||
| metadata: | ||||
|   name: default | ||||
| @@ -395,39 +456,6 @@ spec: | ||||
|   sniStrict: true | ||||
| ``` | ||||
|  | ||||
| ### Prefer Server Cipher Suites | ||||
|  | ||||
| This option allows the server to choose its most preferred cipher suite instead of the client's. | ||||
| Please note that this is enabled automatically when `minVersion` or `maxVersion` are set. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Dynamic configuration | ||||
|  | ||||
| tls: | ||||
|   options: | ||||
|     default: | ||||
|       preferServerCipherSuites: true | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| # Dynamic configuration | ||||
|  | ||||
| [tls.options] | ||||
|   [tls.options.default] | ||||
|     preferServerCipherSuites = true | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| kind: TLSOption | ||||
| metadata: | ||||
|   name: default | ||||
|   namespace: default | ||||
|  | ||||
| spec: | ||||
|   preferServerCipherSuites: true | ||||
| ``` | ||||
|  | ||||
| ### ALPN Protocols | ||||
|  | ||||
| _Optional, Default="h2, http/1.1, acme-tls/1"_ | ||||
| @@ -457,7 +485,7 @@ tls: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSOption | ||||
| metadata: | ||||
|   name: default | ||||
| @@ -473,15 +501,17 @@ spec: | ||||
|  | ||||
| Traefik supports mutual authentication, through the `clientAuth` section. | ||||
|  | ||||
| For authentication policies that require verification of the client certificate, the certificate authority for the certificate should be set in `clientAuth.caFiles`. | ||||
| For authentication policies that require verification of the client certificate, the certificate authority for the certificates should be set in `clientAuth.caFiles`. | ||||
|  | ||||
| In Kubernetes environment, CA certificate can be set in `clientAuth.secretNames`. See [TLSOption resource](../../routing/providers/kubernetes-crd#kind-tlsoption) for more details. | ||||
|  | ||||
| The `clientAuth.clientAuthType` option governs the behaviour as follows: | ||||
|  | ||||
| - `NoClientCert`: disregards any client certificate. | ||||
| - `RequestClientCert`: asks for a certificate but proceeds anyway if none is provided. | ||||
| - `RequireAnyClientCert`: requires a certificate but does not verify if it is signed by a CA listed in `clientAuth.caFiles`. | ||||
| - `VerifyClientCertIfGiven`: if a certificate is provided, verifies if it is signed by a CA listed in `clientAuth.caFiles`. Otherwise proceeds without any certificate. | ||||
| - `RequireAndVerifyClientCert`: requires a certificate, which must be signed by a CA listed in `clientAuth.caFiles`. | ||||
| - `RequireAnyClientCert`: requires a certificate but does not verify if it is signed by a CA listed in `clientAuth.caFiles` or in `clientAuth.secretNames`. | ||||
| - `VerifyClientCertIfGiven`: if a certificate is provided, verifies if it is signed by a CA listed in `clientAuth.caFiles` or in `clientAuth.secretNames`. Otherwise proceeds without any certificate. | ||||
| - `RequireAndVerifyClientCert`: requires a certificate, which must be signed by a CA listed in `clientAuth.caFiles` or in `clientAuth.secretNames`. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Dynamic configuration | ||||
| @@ -509,7 +539,7 @@ tls: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: TLSOption | ||||
| metadata: | ||||
|   name: default | ||||
| @@ -522,3 +552,5 @@ spec: | ||||
|       - secretCA | ||||
|     clientAuthType: RequireAndVerifyClientCert | ||||
| ``` | ||||
|  | ||||
| {!traefik-for-business-applications.md!} | ||||
|   | ||||
							
								
								
									
										4
									
								
								docs/content/includes/.markdownlint.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								docs/content/includes/.markdownlint.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| { | ||||
|   "extends": "../../.markdownlint.json", | ||||
|   "MD041": false | ||||
| } | ||||
							
								
								
									
										3
									
								
								docs/content/includes/kubernetes-requirements.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								docs/content/includes/kubernetes-requirements.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| Traefik follows the [Kubernetes support policy](https://kubernetes.io/releases/version-skew-policy/#supported-versions), | ||||
| and supports at least the latest three minor versions of Kubernetes. | ||||
| General functionality cannot be guaranteed for versions older than that. | ||||
							
								
								
									
										11
									
								
								docs/content/includes/traefik-api-management-kubernetes.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								docs/content/includes/traefik-api-management-kubernetes.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| --- | ||||
|  | ||||
| !!! question "Managing APIs in Kubernetes?" | ||||
|  | ||||
|     If your organization is publishing, securing, and managing APIs, consider [Traefik Hub](https://traefik.io/traefik-hub/) for your API management solution. | ||||
|      | ||||
|     - K8s services auto-discovery, 100% CRDs configuration, & full GitOps compliance | ||||
|     - Centralized control plane for all APIs, users, & infrastructure components | ||||
|     - Self-serve API portal with API discovery, documentation, testing, & access control | ||||
|  | ||||
|     Traefik Hub makes managing APIs easier than ever before. See for yourself in this [short video walkthrough](https://info.traefik.io/watch-traefik-hub-demo). | ||||
							
								
								
									
										11
									
								
								docs/content/includes/traefik-for-business-applications.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								docs/content/includes/traefik-for-business-applications.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| --- | ||||
|  | ||||
| !!! question "Using Traefik for Business Applications?" | ||||
|  | ||||
|     If you are using Traefik in your organization, consider [Traefik Enterprise](https://traefik.io/traefik-enterprise/). You can use it as your: | ||||
|  | ||||
|     - [API Gateway](https://traefik.io/solutions/api-gateway/) | ||||
|     - [Kubernetes Ingress Controller](https://traefik.io/solutions/kubernetes-ingress/) | ||||
|     - [Docker Swarm Ingress Controller](https://traefik.io/solutions/docker-swarm-ingress/) | ||||
|  | ||||
|     Traefik Enterprise simplifies the discovery, security, and deployment of APIs and microservices across any environment. See it in action in [this short video walkthrough](https://info.traefik.io/watch-traefikee-demo). | ||||
| @@ -13,7 +13,7 @@ It receives requests on behalf of your system and finds out which components are | ||||
| What sets Traefik apart, besides its many features, is that it automatically discovers the right configuration for your services.  | ||||
| The magic happens when Traefik inspects your infrastructure, where it finds relevant information and discovers which service serves which request.  | ||||
|  | ||||
| Traefik is natively compliant with every major cluster technology, such as Kubernetes, Docker, Docker Swarm, AWS, Mesos, Marathon, and [the list goes on](providers/overview.md); and can handle many at the same time. (It even works for legacy software running on bare metal.) | ||||
| Traefik is natively compliant with every major cluster technology, such as Kubernetes, Docker, Docker Swarm, AWS, and [the list goes on](providers/overview.md); and can handle many at the same time. (It even works for legacy software running on bare metal.) | ||||
|   | ||||
| With Traefik, there is no need to maintain and synchronize a separate configuration file: everything happens automatically, in real time (no restarts, no connection interruptions). | ||||
| With Traefik, you spend time developing and deploying new features to your system, not on configuring and maintaining its working state.    | ||||
| @@ -24,9 +24,8 @@ Developing Traefik, our main goal is to make it simple to use, and we're sure yo | ||||
|  | ||||
| !!! info | ||||
|  | ||||
|     Join our user friendly and active [Community Forum](https://community.traefik.io) to discuss, learn, and connect with the traefik community. | ||||
|      | ||||
|     If you're a business running critical services behind Traefik, | ||||
|     know that [Traefik Labs](https://traefik.io), the company that sponsors Traefik's development, | ||||
|     can provide [commercial support](https://info.traefik.io/commercial-services) | ||||
|     and develops an [Enterprise Edition](https://traefik.io/traefik-enterprise/) of Traefik. | ||||
|     Join our user friendly and active [Community Forum](https://community.traefik.io "Link to Traefik Community Forum") to discuss, learn, and connect with the traefik community. | ||||
|  | ||||
|     Using Traefik in your organization? Consider [Traefik Enterprise](https://traefik.io/traefik-enterprise/ "Lino to Traefik Enterprise"), our unified API Gateway and Ingress that simplifies the discovery, security, and deployment of APIs and microservices across any environment. | ||||
|  | ||||
|     See it in action in [this short video walkthrough](https://info.traefik.io/watch-traefikee-demo "Link to video walkthrough"). | ||||
|   | ||||
| @@ -14,7 +14,7 @@ The AddPrefix middleware updates the path of a request before forwarding it. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Prefixing with /foo | ||||
| labels: | ||||
|   - "traefik.http.middlewares.add-foo.addprefix.prefix=/foo" | ||||
| @@ -22,7 +22,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Prefixing with /foo | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: add-foo | ||||
| @@ -36,18 +36,6 @@ spec: | ||||
| - "traefik.http.middlewares.add-foo.addprefix.prefix=/foo" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.add-foo.addprefix.prefix": "/foo" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Prefixing with /foo | ||||
| labels: | ||||
|   - "traefik.http.middlewares.add-foo.addprefix.prefix=/foo" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Prefixing with /foo | ||||
| http: | ||||
|   | ||||
| @@ -14,7 +14,7 @@ The BasicAuth middleware restricts access to your services to known users. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Declaring the user list | ||||
| # | ||||
| # Note: when used in docker-compose.yml all dollar signs in the hash need to be doubled for escaping. | ||||
| @@ -28,7 +28,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Declaring the user list | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -41,18 +41,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.basicauth.users=test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/,test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.basicauth.users": "test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/,test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Declaring the user list | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.basicauth.users=test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/,test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Declaring the user list | ||||
| http: | ||||
| @@ -100,7 +88,7 @@ The `users` option is an array of authorized users. Each user must be declared u | ||||
|     Please note that these keys are not hashed or encrypted in any way, and therefore is less secure than other methods. | ||||
|     You can find more information on the [Kubernetes Basic Authentication Secret Documentation](https://kubernetes.io/docs/concepts/configuration/secret/#basic-authentication-secret) | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Declaring the user list | ||||
| # | ||||
| # Note: when used in docker-compose.yml all dollar signs in the hash need to be doubled for escaping. | ||||
| @@ -114,7 +102,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Declaring the user list | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -157,18 +145,6 @@ data: | ||||
| - "traefik.http.middlewares.test-auth.basicauth.users=test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/,test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.basicauth.users": "test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/,test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Declaring the user list | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.basicauth.users=test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/,test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Declaring the user list | ||||
| http: | ||||
| @@ -201,13 +177,13 @@ The file content is a list of `name:hashed-password`. | ||||
|     - If both `users` and `usersFile` are provided, the two are merged. The contents of `usersFile` have precedence over the values in `users`. | ||||
|     - Because it does not make much sense to refer to a file path on Kubernetes, the `usersFile` field doesn't exist for Kubernetes IngressRoute, and one should use the `secret` field instead. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.basicauth.usersfile=/path/to/my/usersfile" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -232,17 +208,6 @@ data: | ||||
| - "traefik.http.middlewares.test-auth.basicauth.usersfile=/path/to/my/usersfile" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.basicauth.usersfile": "/path/to/my/usersfile" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.basicauth.usersfile=/path/to/my/usersfile" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -268,13 +233,13 @@ http: | ||||
|  | ||||
| You can customize the realm for the authentication with the `realm` option. The default value is `traefik`. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.basicauth.realm=MyRealm" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -287,17 +252,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.basicauth.realm=MyRealm" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.basicauth.realm": "MyRealm" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.basicauth.realm=MyRealm" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -316,13 +270,13 @@ http: | ||||
|  | ||||
| You can define a header field to store the authenticated user using the `headerField`option. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.my-auth.basicauth.headerField=X-WebAuth-User" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: my-auth | ||||
| @@ -336,12 +290,6 @@ spec: | ||||
| - "traefik.http.middlewares.my-auth.basicauth.headerField=X-WebAuth-User" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.my-auth.basicauth.headerField": "X-WebAuth-User" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -361,13 +309,13 @@ http: | ||||
|  | ||||
| Set the `removeHeader` option to `true` to remove the authorization header before forwarding the request to your service. (Default value is `false`.) | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.basicauth.removeheader=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -380,17 +328,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.basicauth.removeheader=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.basicauth.removeheader": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.basicauth.removeheader=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
|   | ||||
| @@ -18,7 +18,7 @@ This can help services avoid large amounts of data (`multipart/form-data` for ex | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Sets the maximum request body to 2MB | ||||
| labels: | ||||
|   - "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000" | ||||
| @@ -26,7 +26,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Sets the maximum request body to 2MB | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: limit | ||||
| @@ -40,18 +40,6 @@ spec: | ||||
| - "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes": "2000000" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Sets the maximum request body to 2MB | ||||
| labels: | ||||
|   - "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Sets the maximum request body to 2MB | ||||
| http: | ||||
| @@ -78,13 +66,13 @@ The `maxRequestBodyBytes` option configures the maximum allowed body size for th | ||||
|  | ||||
| If the request exceeds the allowed size, it is not forwarded to the service, and the client gets a `413` (Request Entity Too Large) response. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: limit | ||||
| @@ -97,17 +85,6 @@ spec: | ||||
| - "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes": "2000000" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -128,13 +105,13 @@ _Optional, Default=1048576_ | ||||
|  | ||||
| You can configure a threshold (in bytes) from which the request will be buffered on disk instead of in memory with the `memRequestBodyBytes` option. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.limit.buffering.memRequestBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: limit | ||||
| @@ -147,17 +124,6 @@ spec: | ||||
| - "traefik.http.middlewares.limit.buffering.memRequestBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.limit.buffering.memRequestBodyBytes": "2000000" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.limit.buffering.memRequestBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -180,13 +146,13 @@ The `maxResponseBodyBytes` option configures the maximum allowed response size f | ||||
|  | ||||
| If the response exceeds the allowed size, it is not forwarded to the client. The client gets a `500` (Internal Server Error) response instead. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.limit.buffering.maxResponseBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: limit | ||||
| @@ -199,17 +165,6 @@ spec: | ||||
| - "traefik.http.middlewares.limit.buffering.maxResponseBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.limit.buffering.maxResponseBodyBytes": "2000000" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.limit.buffering.maxResponseBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -230,13 +185,13 @@ _Optional, Default=1048576_ | ||||
|  | ||||
| You can configure a threshold (in bytes) from which the response will be buffered on disk instead of in memory with the `memResponseBodyBytes` option. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.limit.buffering.memResponseBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: limit | ||||
| @@ -249,17 +204,6 @@ spec: | ||||
| - "traefik.http.middlewares.limit.buffering.memResponseBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.limit.buffering.memResponseBodyBytes": "2000000" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.limit.buffering.memResponseBodyBytes=2000000" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -282,13 +226,13 @@ You can have the Buffering middleware replay the request using `retryExpression` | ||||
|  | ||||
| ??? example "Retries once in the case of a network error" | ||||
|  | ||||
|     ```yaml tab="Docker" | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     labels: | ||||
|       - "traefik.http.middlewares.limit.buffering.retryExpression=IsNetworkError() && Attempts() < 2" | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="Kubernetes" | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: Middleware | ||||
|     metadata: | ||||
|       name: limit | ||||
| @@ -301,17 +245,6 @@ You can have the Buffering middleware replay the request using `retryExpression` | ||||
|     - "traefik.http.middlewares.limit.buffering.retryExpression=IsNetworkError() && Attempts() < 2" | ||||
|     ``` | ||||
|  | ||||
|     ```json tab="Marathon" | ||||
|     "labels": { | ||||
|       "traefik.http.middlewares.limit.buffering.retryExpression": "IsNetworkError() && Attempts() < 2" | ||||
|     } | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="Rancher" | ||||
|     labels: | ||||
|       - "traefik.http.middlewares.limit.buffering.retryExpression=IsNetworkError() && Attempts() < 2" | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="File (YAML)" | ||||
|     http: | ||||
|       middlewares: | ||||
|   | ||||
| @@ -15,9 +15,9 @@ It makes reusing the same groups easier. | ||||
|  | ||||
| ## Configuration Example | ||||
|  | ||||
| Below is an example of a Chain containing `WhiteList`, `BasicAuth`, and `RedirectScheme`. | ||||
| Below is an example of a Chain containing `AllowList`, `BasicAuth`, and `RedirectScheme`. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.routers.router1.service=service1" | ||||
|   - "traefik.http.routers.router1.middlewares=secured" | ||||
| @@ -25,12 +25,12 @@ labels: | ||||
|   - "traefik.http.middlewares.secured.chain.middlewares=https-only,known-ips,auth-users" | ||||
|   - "traefik.http.middlewares.auth-users.basicauth.users=test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/" | ||||
|   - "traefik.http.middlewares.https-only.redirectscheme.scheme=https" | ||||
|   - "traefik.http.middlewares.known-ips.ipwhitelist.sourceRange=192.168.1.7,127.0.0.1/32" | ||||
|   - "traefik.http.middlewares.known-ips.ipallowlist.sourceRange=192.168.1.7,127.0.0.1/32" | ||||
|   - "traefik.http.services.service1.loadbalancer.server.port=80" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: IngressRoute | ||||
| metadata: | ||||
|   name: test | ||||
| @@ -47,7 +47,7 @@ spec: | ||||
|       middlewares: | ||||
|         - name: secured | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: secured | ||||
| @@ -58,7 +58,7 @@ spec: | ||||
|     - name: known-ips | ||||
|     - name: auth-users | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: auth-users | ||||
| @@ -67,7 +67,7 @@ spec: | ||||
|     users: | ||||
|     - test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/ | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: https-only | ||||
| @@ -75,12 +75,12 @@ spec: | ||||
|   redirectScheme: | ||||
|     scheme: https | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: known-ips | ||||
| spec: | ||||
|   ipWhiteList: | ||||
|   ipAllowList: | ||||
|     sourceRange: | ||||
|     - 192.168.1.7 | ||||
|     - 127.0.0.1/32 | ||||
| @@ -93,35 +93,10 @@ spec: | ||||
| - "traefik.http.middlewares.secured.chain.middlewares=https-only,known-ips,auth-users" | ||||
| - "traefik.http.middlewares.auth-users.basicauth.users=test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/" | ||||
| - "traefik.http.middlewares.https-only.redirectscheme.scheme=https" | ||||
| - "traefik.http.middlewares.known-ips.ipwhitelist.sourceRange=192.168.1.7,127.0.0.1/32" | ||||
| - "traefik.http.middlewares.known-ips.ipallowlist.sourceRange=192.168.1.7,127.0.0.1/32" | ||||
| - "traefik.http.services.service1.loadbalancer.server.port=80" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.routers.router1.service": "service1", | ||||
|   "traefik.http.routers.router1.middlewares": "secured", | ||||
|   "traefik.http.routers.router1.rule": "Host(`mydomain`)", | ||||
|   "traefik.http.middlewares.secured.chain.middlewares": "https-only,known-ips,auth-users", | ||||
|   "traefik.http.middlewares.auth-users.basicauth.users": "test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/", | ||||
|   "traefik.http.middlewares.https-only.redirectscheme.scheme": "https", | ||||
|   "traefik.http.middlewares.known-ips.ipwhitelist.sourceRange": "192.168.1.7,127.0.0.1/32", | ||||
|   "traefik.http.services.service1.loadbalancer.server.port": "80" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.routers.router1.service=service1" | ||||
|   - "traefik.http.routers.router1.middlewares=secured" | ||||
|   - "traefik.http.routers.router1.rule=Host(`mydomain`)" | ||||
|   - "traefik.http.middlewares.secured.chain.middlewares=https-only,known-ips,auth-users" | ||||
|   - "traefik.http.middlewares.auth-users.basicauth.users=test:$apr1$H6uskkkW$IgXLP6ewTrSuBkTrqE8wj/" | ||||
|   - "traefik.http.middlewares.https-only.redirectscheme.scheme=https" | ||||
|   - "traefik.http.middlewares.known-ips.ipwhitelist.sourceRange=192.168.1.7,127.0.0.1/32" | ||||
|   - "traefik.http.services.service1.loadbalancer.server.port=80" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # ... | ||||
| http: | ||||
| @@ -150,7 +125,7 @@ http: | ||||
|         scheme: https | ||||
|  | ||||
|     known-ips: | ||||
|       ipWhiteList: | ||||
|       ipAllowList: | ||||
|         sourceRange: | ||||
|           - "192.168.1.7" | ||||
|           - "127.0.0.1/32" | ||||
| @@ -180,7 +155,7 @@ http: | ||||
|   [http.middlewares.https-only.redirectScheme] | ||||
|     scheme = "https" | ||||
|  | ||||
|   [http.middlewares.known-ips.ipWhiteList] | ||||
|   [http.middlewares.known-ips.ipAllowList] | ||||
|     sourceRange = ["192.168.1.7", "127.0.0.1/32"] | ||||
|  | ||||
| [http.services] | ||||
|   | ||||
| @@ -30,7 +30,7 @@ To assess if your system is healthy, the circuit breaker constantly monitors the | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Latency Check | ||||
| labels: | ||||
|   - "traefik.http.middlewares.latency-check.circuitbreaker.expression=LatencyAtQuantileMS(50.0) > 100" | ||||
| @@ -38,7 +38,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Latency Check | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: latency-check | ||||
| @@ -52,18 +52,6 @@ spec: | ||||
| - "traefik.http.middlewares.latency-check.circuitbreaker.expression=LatencyAtQuantileMS(50.0) > 100" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.latency-check.circuitbreaker.expression": "LatencyAtQuantileMS(50.0) > 100" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Latency Check | ||||
| labels: | ||||
|   - "traefik.http.middlewares.latency-check.circuitbreaker.expression=LatencyAtQuantileMS(50.0) > 100" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Latency Check | ||||
| http: | ||||
| @@ -176,15 +164,18 @@ This behavior cannot be configured. | ||||
|  | ||||
| ### `CheckPeriod` | ||||
|  | ||||
| The interval used to evaluate `expression` and decide if the state of the circuit breaker must change. | ||||
| By default, `CheckPeriod` is 100ms. This value cannot be configured. | ||||
| _Optional, Default="100ms"_ | ||||
|  | ||||
| The interval between successive checks of the circuit breaker condition (when in standby state). | ||||
|  | ||||
| ### `FallbackDuration` | ||||
|  | ||||
| By default, `FallbackDuration` is 10 seconds. This value cannot be configured. | ||||
| _Optional, Default="10s"_ | ||||
|  | ||||
| ### `RecoveringDuration` | ||||
| The duration for which the circuit breaker will wait before trying to recover (from a tripped state). | ||||
|  | ||||
| The duration of the recovering mode (recovering state). | ||||
| ### `RecoveryDuration` | ||||
|  | ||||
| By default, `RecoveringDuration` is 10 seconds. This value cannot be configured. | ||||
| _Optional, Default="10s"_ | ||||
|  | ||||
| The duration for which the circuit breaker will try to recover (as soon as it is in recovering state). | ||||
|   | ||||
| @@ -5,24 +5,25 @@ description: "Traefik Proxy's HTTP middleware lets you compress responses before | ||||
|  | ||||
| # Compress | ||||
|  | ||||
| Compress Responses before Sending them to the Client | ||||
| Compress Allows Compressing Responses before Sending them to the Client | ||||
| {: .subtitle } | ||||
|  | ||||
|  | ||||
|  | ||||
| The Compress middleware uses gzip compression. | ||||
| The Compress middleware supports gzip and Brotli compression. | ||||
| The activation of compression, and the compression method choice rely (among other things) on the request's `Accept-Encoding` header. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| # Enable gzip compression | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Enable compression | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-compress.compress=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Enable gzip compression | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| # Enable compression | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-compress | ||||
| @@ -31,24 +32,12 @@ spec: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Consul Catalog" | ||||
| # Enable gzip compression | ||||
| # Enable compression | ||||
| - "traefik.http.middlewares.test-compress.compress=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-compress.compress": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Enable gzip compression | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-compress.compress=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Enable gzip compression | ||||
| # Enable compression | ||||
| http: | ||||
|   middlewares: | ||||
|     test-compress: | ||||
| @@ -56,7 +45,7 @@ http: | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| # Enable gzip compression | ||||
| # Enable compression | ||||
| [http.middlewares] | ||||
|   [http.middlewares.test-compress.compress] | ||||
| ``` | ||||
| @@ -65,30 +54,41 @@ http: | ||||
|  | ||||
|     Responses are compressed when the following criteria are all met: | ||||
|  | ||||
|     * The response body is larger than the configured minimum amount of bytes (default is `1024`). | ||||
|     * The `Accept-Encoding` request header contains `gzip`. | ||||
|     * The `Accept-Encoding` request header contains `gzip`, `*`, and/or `br` with or without [quality values](https://developer.mozilla.org/en-US/docs/Glossary/Quality_values). | ||||
|     If the `Accept-Encoding` request header is absent, it is meant as br compression is requested. | ||||
|     If it is present, but its value is the empty string, then compression is disabled. | ||||
|     * The response is not already compressed, i.e. the `Content-Encoding` response header is not already set. | ||||
|  | ||||
|     If the `Content-Type` header is not defined, or empty, the compress middleware will automatically [detect](https://mimesniff.spec.whatwg.org/) a content type. | ||||
|     It will also set the `Content-Type` header according to the detected MIME type. | ||||
|     * The response`Content-Type` header is not one among the [excludedContentTypes options](#excludedcontenttypes). | ||||
|     * The response body is larger than the [configured minimum amount of bytes](#minresponsebodybytes) (default is `1024`). | ||||
|  | ||||
| ## Configuration Options | ||||
|  | ||||
| ### `excludedContentTypes` | ||||
|  | ||||
| _Optional, Default=""_  | ||||
|  | ||||
| `excludedContentTypes` specifies a list of content types to compare the `Content-Type` header of the incoming requests and responses before compressing. | ||||
|  | ||||
| The responses with content types defined in `excludedContentTypes` are not compressed. | ||||
|  | ||||
| Content types are compared in a case-insensitive, whitespace-ignored manner. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| !!! info "In the case of gzip" | ||||
|  | ||||
|     If the `Content-Type` header is not defined, or empty, the compress middleware will automatically [detect](https://mimesniff.spec.whatwg.org/) a content type. | ||||
|     It will also set the `Content-Type` header according to the detected MIME type. | ||||
|  | ||||
| !!! info "gRPC" | ||||
|  | ||||
|     Note that `application/grpc` is never compressed. | ||||
|  | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-compress.compress.excludedcontenttypes=text/event-stream" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-compress | ||||
| @@ -102,17 +102,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-compress.compress.excludedcontenttypes=text/event-stream" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-compress.compress.excludedcontenttypes": "text/event-stream" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-compress.compress.excludedcontenttypes=text/event-stream" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -130,19 +119,19 @@ http: | ||||
|  | ||||
| ### `minResponseBodyBytes` | ||||
|  | ||||
| `minResponseBodyBytes` specifies the minimum amount of bytes a response body must have to be compressed. | ||||
| _Optional, Default=1024_ | ||||
|  | ||||
| The default value is `1024`, which should be a reasonable value for most cases. | ||||
| `minResponseBodyBytes` specifies the minimum amount of bytes a response body must have to be compressed. | ||||
|  | ||||
| Responses smaller than the specified values will not be compressed. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-compress.compress.minresponsebodybytes=1200" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-compress | ||||
| @@ -155,17 +144,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-compress.compress.minresponsebodybytes=1200" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-compress.compress.minresponsebodybytes": 1200 | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-compress.compress.minresponsebodybytes=1200" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| --- | ||||
| title: "Traefik ContentType Documentation" | ||||
| description: "Traefik Proxy's HTTP middleware can automatically specify the content-type header if it has not been defined by the backend. Read the technical documentation." | ||||
| description: "Traefik Proxy's HTTP middleware automatically sets the `Content-Type` header value when it is not set by the backend. Read the technical documentation." | ||||
| --- | ||||
|  | ||||
| # ContentType | ||||
| @@ -8,84 +8,47 @@ description: "Traefik Proxy's HTTP middleware can automatically specify the cont | ||||
| Handling Content-Type auto-detection | ||||
| {: .subtitle } | ||||
|  | ||||
| The Content-Type middleware - or rather its `autoDetect` option - | ||||
| specifies whether to let the `Content-Type` header, | ||||
| if it has not been defined by the backend, | ||||
| be automatically set to a value derived from the contents of the response. | ||||
|  | ||||
| As a proxy, the default behavior should be to leave the header alone, | ||||
| regardless of what the backend did with it. | ||||
| However, the historic default was to always auto-detect and set the header if it was not already defined, | ||||
| and altering this behavior would be a breaking change which would impact many users. | ||||
|  | ||||
| This middleware exists to enable the correct behavior until at least the default one can be changed in a future version. | ||||
| The Content-Type middleware sets the `Content-Type` header value to the media type detected from the response content, | ||||
| when it is not set by the backend. | ||||
|  | ||||
| !!! info | ||||
|  | ||||
|     As explained above, for compatibility reasons the default behavior on a router (without this middleware), | ||||
|     is still to automatically set the `Content-Type` header. | ||||
|     Therefore, given the default value of the `autoDetect` option (false), | ||||
|     simply enabling this middleware for a router switches the router's behavior. | ||||
|  | ||||
|     The scope of the Content-Type middleware is the MIME type detection done by the core of Traefik (the server part). | ||||
|     Therefore, it has no effect against any other `Content-Type` header modifications (e.g.: in another middleware such as compress). | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| # Disable auto-detection | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Enable auto-detection | ||||
| labels: | ||||
|   - "traefik.http.middlewares.autodetect.contenttype.autodetect=false" | ||||
|   - "traefik.http.middlewares.autodetect.contenttype=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Disable auto-detection | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| # Enable auto-detection | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: autodetect | ||||
| spec: | ||||
|   contentType: | ||||
|     autoDetect: false | ||||
|   contentType: {} | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Consul Catalog" | ||||
| # Disable auto-detection | ||||
| - "traefik.http.middlewares.autodetect.contenttype.autodetect=false" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.autodetect.contenttype.autodetect": "false" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Disable auto-detection | ||||
| labels: | ||||
|   - "traefik.http.middlewares.autodetect.contenttype.autodetect=false" | ||||
| # Enable auto-detection | ||||
| - "traefik.http.middlewares.autodetect.contenttype=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Disable auto-detection | ||||
| # Enable auto-detection | ||||
| http: | ||||
|   middlewares: | ||||
|     autodetect: | ||||
|       contentType: | ||||
|         autoDetect: false | ||||
|       contentType: {} | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| # Disable auto-detection | ||||
| # Enable auto-detection | ||||
| [http.middlewares] | ||||
|   [http.middlewares.autodetect.contentType] | ||||
|      autoDetect=false | ||||
| ``` | ||||
|  | ||||
| ## Configuration Options | ||||
|  | ||||
| ### `autoDetect` | ||||
|  | ||||
| `autoDetect` specifies whether to let the `Content-Type` header, | ||||
| if it has not been set by the backend, | ||||
| be automatically set to a value derived from the contents of the response. | ||||
|   | ||||
| @@ -14,7 +14,7 @@ The DigestAuth middleware restricts access to your services to known users. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Declaring the user list | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.digestauth.users=test:traefik:a2688e031edb4be6a3797f3882655c05,test2:traefik:518845800f9e2bfb1f1f740ec24f074e" | ||||
| @@ -22,7 +22,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Declaring the user list | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -36,18 +36,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.digestauth.users=test:traefik:a2688e031edb4be6a3797f3882655c05,test2:traefik:518845800f9e2bfb1f1f740ec24f074e" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.digestauth.users": "test:traefik:a2688e031edb4be6a3797f3882655c05,test2:traefik:518845800f9e2bfb1f1f740ec24f074e" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Declaring the user list | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.digestauth.users=test:traefik:a2688e031edb4be6a3797f3882655c05,test2:traefik:518845800f9e2bfb1f1f740ec24f074e" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Declaring the user list | ||||
| http: | ||||
| @@ -84,13 +72,13 @@ The `users` option is an array of authorized users. Each user will be declared u | ||||
|     - If both `users` and `usersFile` are provided, the two are merged. The contents of `usersFile` have precedence over the values in `users`. | ||||
|     - For security reasons, the field `users` doesn't exist for Kubernetes IngressRoute, and one should use the `secret` field instead. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.digestauth.users=test:traefik:a2688e031edb4be6a3797f3882655c05,test2:traefik:518845800f9e2bfb1f1f740ec24f074e" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -114,17 +102,6 @@ data: | ||||
| - "traefik.http.middlewares.test-auth.digestauth.users=test:traefik:a2688e031edb4be6a3797f3882655c05,test2:traefik:518845800f9e2bfb1f1f740ec24f074e" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.digestauth.users": "test:traefik:a2688e031edb4be6a3797f3882655c05,test2:traefik:518845800f9e2bfb1f1f740ec24f074e" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.digestauth.users=test:traefik:a2688e031edb4be6a3797f3882655c05,test2:traefik:518845800f9e2bfb1f1f740ec24f074e" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -155,13 +132,13 @@ The file content is a list of `name:realm:encoded-password`. | ||||
|     - If both `users` and `usersFile` are provided, the two are merged. The contents of `usersFile` have precedence over the values in `users`. | ||||
|     - Because it does not make much sense to refer to a file path on Kubernetes, the `usersFile` field doesn't exist for Kubernetes IngressRoute, and one should use the `secret` field instead. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.digestauth.usersfile=/path/to/my/usersfile" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -186,17 +163,6 @@ data: | ||||
| - "traefik.http.middlewares.test-auth.digestauth.usersfile=/path/to/my/usersfile" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.digestauth.usersfile": "/path/to/my/usersfile" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.digestauth.usersfile=/path/to/my/usersfile" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -222,13 +188,13 @@ http: | ||||
|  | ||||
| You can customize the realm for the authentication with the `realm` option. The default value is `traefik`. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.digestauth.realm=MyRealm" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -241,17 +207,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.digestauth.realm=MyRealm" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.digestauth.realm": "MyRealm" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.digestauth.realm=MyRealm" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -270,13 +225,13 @@ http: | ||||
|  | ||||
| You can customize the header field for the authenticated user using the `headerField`option. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.my-auth.digestauth.headerField=X-WebAuth-User" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: my-auth | ||||
| @@ -290,17 +245,6 @@ spec: | ||||
| - "traefik.http.middlewares.my-auth.digestauth.headerField=X-WebAuth-User" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.my-auth.digestauth.headerField": "X-WebAuth-User" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.my-auth.digestauth.headerField=X-WebAuth-User" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -320,13 +264,13 @@ http: | ||||
|  | ||||
| Set the `removeHeader` option to `true` to remove the authorization header before forwarding the request to your service. (Default value is `false`.) | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.digestauth.removeheader=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -339,17 +283,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.digestauth.removeheader=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.digestauth.removeheader": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.digestauth.removeheader=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
|   | ||||
| @@ -1,16 +1,16 @@ | ||||
| --- | ||||
| title: "Traefik ErrorPage Documentation" | ||||
| description: "In Traefik Proxy, the ErrorPage middleware returns custom pages according to configured ranges of HTTP Status codes. Read the technical documentation." | ||||
| title: "Traefik Errors Documentation" | ||||
| description: "In Traefik Proxy, the Errors middleware returns custom pages according to configured ranges of HTTP Status codes. Read the technical documentation." | ||||
| --- | ||||
|  | ||||
| # ErrorPage | ||||
| # Errors | ||||
|  | ||||
| It Has Never Been Easier to Say That Something Went Wrong | ||||
| {: .subtitle } | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| The ErrorPage middleware returns a custom page in lieu of the default, according to configured ranges of HTTP Status codes. | ||||
| The Errors middleware returns a custom page in lieu of the default, according to configured ranges of HTTP Status codes. | ||||
|  | ||||
| !!! important | ||||
|  | ||||
| @@ -18,19 +18,19 @@ The ErrorPage middleware returns a custom page in lieu of the default, according | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Dynamic Custom Error Page for 5XX Status Code | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-errorpage.errors.status=500-599" | ||||
|   - "traefik.http.middlewares.test-errorpage.errors.service=serviceError" | ||||
|   - "traefik.http.middlewares.test-errorpage.errors.query=/{status}.html" | ||||
|   - "traefik.http.middlewares.test-errors.errors.status=500-599" | ||||
|   - "traefik.http.middlewares.test-errors.errors.service=serviceError" | ||||
|   - "traefik.http.middlewares.test-errors.errors.query=/{status}.html" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-errorpage | ||||
|   name: test-errors | ||||
| spec: | ||||
|   errors: | ||||
|     status: | ||||
| @@ -43,32 +43,16 @@ spec: | ||||
|  | ||||
| ```yaml tab="Consul Catalog" | ||||
| # Dynamic Custom Error Page for 5XX Status Code | ||||
| - "traefik.http.middlewares.test-errorpage.errors.status=500-599" | ||||
| - "traefik.http.middlewares.test-errorpage.errors.service=serviceError" | ||||
| - "traefik.http.middlewares.test-errorpage.errors.query=/{status}.html" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-errorpage.errors.status": "500-599", | ||||
|   "traefik.http.middlewares.test-errorpage.errors.service": "serviceError", | ||||
|   "traefik.http.middlewares.test-errorpage.errors.query": "/{status}.html" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Dynamic Custom Error Page for 5XX Status Code | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-errorpage.errors.status=500-599" | ||||
|   - "traefik.http.middlewares.test-errorpage.errors.service=serviceError" | ||||
|   - "traefik.http.middlewares.test-errorpage.errors.query=/{status}.html" | ||||
| - "traefik.http.middlewares.test-errors.errors.status=500-599" | ||||
| - "traefik.http.middlewares.test-errors.errors.service=serviceError" | ||||
| - "traefik.http.middlewares.test-errors.errors.query=/{status}.html" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Custom Error Page for 5XX | ||||
| http: | ||||
|   middlewares: | ||||
|     test-errorpage: | ||||
|     test-errors: | ||||
|       errors: | ||||
|         status: | ||||
|           - "500-599" | ||||
| @@ -82,7 +66,7 @@ http: | ||||
| ```toml tab="File (TOML)" | ||||
| # Custom Error Page for 5XX | ||||
| [http.middlewares] | ||||
|   [http.middlewares.test-errorpage.errors] | ||||
|   [http.middlewares.test-errors.errors] | ||||
|     status = ["500-599"] | ||||
|     service = "serviceError" | ||||
|     query = "/{status}.html" | ||||
| @@ -121,8 +105,17 @@ The service that will serve the new requested error page. | ||||
| !!! info "Host Header" | ||||
|  | ||||
|     By default, the client `Host` header value is forwarded to the configured error [service](#service). | ||||
|     To forward the `Host` value corresponding to the configured error service URL, the [passHostHeader](../../../routing/services/#pass-host-header) option must be set to `false`.      | ||||
|     To forward the `Host` value corresponding to the configured error service URL, the [passHostHeader](../../../routing/services/#pass-host-header) option must be set to `false`. | ||||
|  | ||||
| ### `query` | ||||
|  | ||||
| The URL for the error page (hosted by `service`). You can use the `{status}` variable in the `query` option in order to insert the status code in the URL. | ||||
| The URL for the error page (hosted by [`service`](#service))). | ||||
|  | ||||
| There are multiple variables that can be placed in the `query` option to insert values in the URL. | ||||
|  | ||||
| The table below lists all the available variables and their associated values. | ||||
|  | ||||
| | Variable   | Value                                                              | | ||||
| |------------|--------------------------------------------------------------------| | ||||
| | `{status}` | The response status code.                                          | | ||||
| | `{url}`    | The [escaped](https://pkg.go.dev/net/url#QueryEscape) request URL. | | ||||
|   | ||||
| @@ -16,7 +16,7 @@ Otherwise, the response from the authentication server is returned. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Forward authentication to example.com | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.address=https://example.com/auth" | ||||
| @@ -24,7 +24,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Forward authentication to example.com | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -38,18 +38,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.address=https://example.com/auth" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.address": "https://example.com/auth" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Forward authentication to example.com | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.address=https://example.com/auth" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Forward authentication to example.com | ||||
| http: | ||||
| @@ -84,13 +72,13 @@ The following request properties are provided to the forward-auth target endpoin | ||||
|  | ||||
| The `address` option defines the authentication server address. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.address=https://example.com/auth" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -103,17 +91,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.address=https://example.com/auth" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.address": "https://example.com/auth" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.address=https://example.com/auth" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -132,13 +109,13 @@ http: | ||||
|  | ||||
| Set the `trustForwardHeader` option to `true` to trust all `X-Forwarded-*` headers. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.trustForwardHeader=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -152,17 +129,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.trustForwardHeader=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.trustForwardHeader": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.trustForwardHeader=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -184,13 +150,13 @@ http: | ||||
| The `authResponseHeaders` option is the list of headers to copy from the authentication server response and set on | ||||
| forwarded request, replacing any existing conflicting headers. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.authResponseHeaders=X-Auth-User, X-Secret" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -206,17 +172,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.authResponseHeaders=X-Auth-User, X-Secret" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.authResponseHeaders": "X-Auth-User,X-Secret" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.authResponseHeaders=X-Auth-User, X-Secret" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -242,13 +197,13 @@ set on forwarded request, after stripping all headers that match the regex. | ||||
| It allows partial matching of the regular expression against the header key. | ||||
| The start of string (`^`) and end of string (`$`) anchors should be used to ensure a full match against the header key. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.authResponseHeadersRegex=^X-" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -262,17 +217,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.authResponseHeadersRegex=^X-" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.authResponseHeadersRegex": "^X-" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.authResponseHeadersRegex=^X-" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -301,13 +245,13 @@ The `authRequestHeaders` option is the list of the headers to copy from the requ | ||||
| It allows filtering headers that should not be passed to the authentication server. | ||||
| If not set or empty then all request headers are passed. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.authRequestHeaders=Accept,X-CustomHeader" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -323,17 +267,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.authRequestHeaders=Accept,X-CustomHeader" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.authRequestHeaders": "Accept,X-CustomHeader" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.authRequestHeaders=Accept,X-CustomHeader" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -365,13 +298,13 @@ _Optional_ | ||||
| `ca` is the path to the certificate authority used for the secured connection to the authentication server, | ||||
| it defaults to the system bundle. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.ca=path/to/local.crt" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -397,17 +330,6 @@ data: | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.tls.ca=path/to/local.crt" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.tls.ca": "path/to/local.crt" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.ca=path/to/local.crt" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -426,70 +348,6 @@ http: | ||||
|       ca = "path/to/local.crt" | ||||
| ``` | ||||
|  | ||||
| #### `caOptional` | ||||
|  | ||||
| _Optional_ | ||||
|  | ||||
| The value of `caOptional` defines which policy should be used for the secure connection with TLS Client Authentication to the authentication server. | ||||
|  | ||||
| !!! warning "" | ||||
|  | ||||
|     If `ca` is undefined, this option will be ignored, and no client certificate will be requested during the handshake. Any provided certificate will thus never be verified. | ||||
|  | ||||
| When this option is set to `true`, a client certificate is requested during the handshake but is not required. If a certificate is sent, it is required to be valid. | ||||
|  | ||||
| When this option is set to `false`, a client certificate is requested during the handshake, and at least one valid certificate should be sent by the client. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.caOptional=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| spec: | ||||
|   forwardAuth: | ||||
|     address: https://example.com/auth | ||||
|     tls: | ||||
|       caOptional: true | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Consul Catalog" | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.tls.caOptional=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.tls.caOptional": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.caOptional=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
|     test-auth: | ||||
|       forwardAuth: | ||||
|         address: "https://example.com/auth" | ||||
|         tls: | ||||
|           caOptional: true | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [http.middlewares] | ||||
|   [http.middlewares.test-auth.forwardAuth] | ||||
|     address = "https://example.com/auth" | ||||
|     [http.middlewares.test-auth.forwardAuth.tls] | ||||
|       caOptional = true | ||||
| ``` | ||||
|  | ||||
| #### `cert` | ||||
|  | ||||
| _Optional_ | ||||
| @@ -497,14 +355,14 @@ _Optional_ | ||||
| `cert` is the path to the public certificate used for the secure connection to the authentication server. | ||||
| When using this option, setting the `key` option is required. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.cert=path/to/foo.cert" | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.key=path/to/foo.key" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -531,19 +389,6 @@ data: | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.tls.key=path/to/foo.key" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.tls.cert": "path/to/foo.cert", | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.tls.key": "path/to/foo.key" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.cert=path/to/foo.cert" | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.key=path/to/foo.key" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -575,14 +420,14 @@ _Optional_ | ||||
| `key` is the path to the private key used for the secure connection to the authentication server. | ||||
| When using this option, setting the `cert` option is required. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.cert=path/to/foo.cert" | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.key=path/to/foo.key" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -609,19 +454,6 @@ data: | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.tls.key=path/to/foo.key" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.tls.cert": "path/to/foo.cert", | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.tls.key": "path/to/foo.key" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.cert=path/to/foo.cert" | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.key=path/to/foo.key" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -652,13 +484,13 @@ _Optional, Default=false_ | ||||
|  | ||||
| If `insecureSkipVerify` is `true`, the TLS connection to the authentication server accepts any certificate presented by the server regardless of the hostnames it covers. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.insecureSkipVerify=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-auth | ||||
| @@ -673,17 +505,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-auth.forwardauth.tls.InsecureSkipVerify=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-auth.forwardauth.tls.insecureSkipVerify": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-auth.forwardauth.tls.InsecureSkipVerify=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
|   | ||||
							
								
								
									
										66
									
								
								docs/content/middlewares/http/grpcweb.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								docs/content/middlewares/http/grpcweb.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | ||||
| --- | ||||
| title: "Traefik GrpcWeb Documentation" | ||||
| description: "In Traefik Proxy's HTTP middleware, GrpcWeb converts a gRPC Web requests to HTTP/2 gRPC requests. Read the technical documentation." | ||||
| --- | ||||
|  | ||||
| # GrpcWeb | ||||
|  | ||||
| Converting gRPC Web requests to HTTP/2 gRPC requests. | ||||
| {: .subtitle } | ||||
|  | ||||
| The GrpcWeb middleware converts gRPC Web requests to HTTP/2 gRPC requests before forwarding them to the backends. | ||||
|  | ||||
| !!! tip | ||||
|  | ||||
|     Please note, that Traefik needs to communicate using gRPC with the backends (h2c or HTTP/2 over TLS). | ||||
|     Check out the [gRPC](../../user-guides/grpc.md) user guide for more details. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-grpcweb.grpcweb.allowOrigins=*" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-grpcweb | ||||
| spec: | ||||
|   grpcWeb: | ||||
|     allowOrigins: | ||||
|       - "*" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Consul Catalog" | ||||
| - "traefik.http.middlewares.test-grpcweb.grpcWeb.allowOrigins=*" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
|     test-grpcweb: | ||||
|       grpcWeb: | ||||
|         allowOrigins: | ||||
|           - "*" | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [http.middlewares] | ||||
|   [http.middlewares.test-grpcweb.grpcWeb] | ||||
|     allowOrigins = ["*"] | ||||
| ``` | ||||
|  | ||||
| ## Configuration Options | ||||
|  | ||||
| ### `allowOrigins` | ||||
|  | ||||
| The `allowOrigins` contains the list of allowed origins. | ||||
| A wildcard origin `*` can also be configured to match all requests. | ||||
|  | ||||
| More information including how to use the settings can be found at: | ||||
|  | ||||
| - [Mozilla.org](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Access-Control-Allow-Origin) | ||||
| - [w3](https://fetch.spec.whatwg.org/#http-access-control-allow-origin) | ||||
| - [IETF](https://tools.ietf.org/html/rfc6454#section-7.1) | ||||
| @@ -20,14 +20,14 @@ A set of forwarded headers are automatically added by default. See the [FAQ](../ | ||||
|  | ||||
| The following example adds the `X-Script-Name` header to the proxied request and the `X-Custom-Response-Header` header to the response | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.testHeader.headers.customrequestheaders.X-Script-Name=test" | ||||
|   - "traefik.http.middlewares.testHeader.headers.customresponseheaders.X-Custom-Response-Header=value" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-header | ||||
| @@ -44,19 +44,6 @@ spec: | ||||
| - "traefik.http.middlewares.testheader.headers.customresponseheaders.X-Custom-Response-Header=value" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Script-Name": "test", | ||||
|   "traefik.http.middlewares.testheader.headers.customresponseheaders.X-Custom-Response-Header": "value" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Script-Name=test" | ||||
|   - "traefik.http.middlewares.testheader.headers.customresponseheaders.X-Custom-Response-Header=value" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -82,7 +69,7 @@ http: | ||||
| In the following example, requests are proxied with an extra `X-Script-Name` header while their `X-Custom-Request-Header` header gets stripped, | ||||
| and responses are stripped of their `X-Custom-Response-Header` header. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Script-Name=test" | ||||
|   - "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Custom-Request-Header=" | ||||
| @@ -90,7 +77,7 @@ labels: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-header | ||||
| @@ -109,21 +96,6 @@ spec: | ||||
| - "traefik.http.middlewares.testheader.headers.customresponseheaders.X-Custom-Response-Header=" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Script-Name": "test", | ||||
|   "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Custom-Request-Header": "", | ||||
|   "traefik.http.middlewares.testheader.headers.customresponseheaders.X-Custom-Response-Header": "", | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Script-Name=test" | ||||
|   - "traefik.http.middlewares.testheader.headers.customrequestheaders.X-Custom-Request-Header=" | ||||
|   - "traefik.http.middlewares.testheader.headers.customresponseheaders.X-Custom-Response-Header=" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -151,14 +123,14 @@ http: | ||||
| Security-related headers (HSTS headers, Browser XSS filter, etc) can be managed similarly to custom headers as shown above. | ||||
| This functionality makes it possible to easily use security features by adding headers. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.testHeader.headers.framedeny=true" | ||||
|   - "traefik.http.middlewares.testHeader.headers.browserxssfilter=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-header | ||||
| @@ -173,19 +145,6 @@ spec: | ||||
| - "traefik.http.middlewares.testheader.headers.browserxssfilter=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.testheader.headers.framedeny": "true", | ||||
|   "traefik.http.middlewares.testheader.headers.browserxssfilter": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.testheader.headers.framedeny=true" | ||||
|   - "traefik.http.middlewares.testheader.headers.browserxssfilter=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -207,18 +166,21 @@ http: | ||||
| CORS (Cross-Origin Resource Sharing) headers can be added and configured in a manner similar to the custom headers above. | ||||
| This functionality allows for more advanced security features to quickly be set. | ||||
| If CORS headers are set, then the middleware does not pass preflight requests to any service, | ||||
| instead the response will be generated and sent back to the client directly. | ||||
| instead the response will be generated and sent back to the client directly.   | ||||
| Please note that the example below is by no means authoritative or exhaustive, | ||||
| and should not be used as is for production. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.testheader.headers.accesscontrolallowmethods=GET,OPTIONS,PUT" | ||||
|   - "traefik.http.middlewares.testheader.headers.accesscontrolallowheaders=*" | ||||
|   - "traefik.http.middlewares.testheader.headers.accesscontrolalloworiginlist=https://foo.bar.org,https://example.org" | ||||
|   - "traefik.http.middlewares.testheader.headers.accesscontrolmaxage=100" | ||||
|   - "traefik.http.middlewares.testheader.headers.addvaryheader=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-header | ||||
| @@ -228,6 +190,7 @@ spec: | ||||
|       - "GET" | ||||
|       - "OPTIONS" | ||||
|       - "PUT" | ||||
|     accessControlAllowHeaders: "*" | ||||
|     accessControlAllowOriginList: | ||||
|       - "https://foo.bar.org" | ||||
|       - "https://example.org" | ||||
| @@ -237,28 +200,12 @@ spec: | ||||
|  | ||||
| ```yaml tab="Consul Catalog" | ||||
| - "traefik.http.middlewares.testheader.headers.accesscontrolallowmethods=GET,OPTIONS,PUT" | ||||
| - "traefik.http.middlewares.testheader.headers.accesscontrolallowheaders=*" | ||||
| - "traefik.http.middlewares.testheader.headers.accesscontrolalloworiginlist=https://foo.bar.org,https://example.org" | ||||
| - "traefik.http.middlewares.testheader.headers.accesscontrolmaxage=100" | ||||
| - "traefik.http.middlewares.testheader.headers.addvaryheader=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.testheader.headers.accesscontrolallowmethods": "GET,OPTIONS,PUT", | ||||
|   "traefik.http.middlewares.testheader.headers.accesscontrolalloworiginlist": "https://foo.bar.org,https://example.org", | ||||
|   "traefik.http.middlewares.testheader.headers.accesscontrolmaxage": "100", | ||||
|   "traefik.http.middlewares.testheader.headers.addvaryheader": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.testheader.headers.accesscontrolallowmethods=GET,OPTIONS,PUT" | ||||
|   - "traefik.http.middlewares.testheader.headers.accesscontrolalloworiginlist=https://foo.bar.org,https://example.org" | ||||
|   - "traefik.http.middlewares.testheader.headers.accesscontrolmaxage=100" | ||||
|   - "traefik.http.middlewares.testheader.headers.addvaryheader=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -268,6 +215,7 @@ http: | ||||
|           - GET | ||||
|           - OPTIONS | ||||
|           - PUT | ||||
|         accessControlAllowHeaders: "*" | ||||
|         accessControlAllowOriginList: | ||||
|           - https://foo.bar.org | ||||
|           - https://example.org | ||||
| @@ -279,6 +227,7 @@ http: | ||||
| [http.middlewares] | ||||
|   [http.middlewares.testHeader.headers] | ||||
|     accessControlAllowMethods= ["GET", "OPTIONS", "PUT"] | ||||
|     accessControlAllowHeaders= "*" | ||||
|     accessControlAllowOriginList = ["https://foo.bar.org","https://example.org"] | ||||
|     accessControlMaxAge = 100 | ||||
|     addVaryHeader = true | ||||
| @@ -364,43 +313,11 @@ The `allowedHosts` option lists fully qualified domain names that are allowed. | ||||
|  | ||||
| The `hostsProxyHeaders` option is a set of header keys that may hold a proxied hostname value for the request. | ||||
|  | ||||
| ### `sslRedirect` | ||||
|  | ||||
| !!! warning | ||||
|  | ||||
|     Deprecated in favor of [EntryPoint redirection](../../routing/entrypoints.md#redirection) or the [RedirectScheme middleware](./redirectscheme.md). | ||||
|  | ||||
| The `sslRedirect` only allow HTTPS requests when set to `true`. | ||||
|  | ||||
| ### `sslTemporaryRedirect` | ||||
|  | ||||
| !!! warning | ||||
|  | ||||
|     Deprecated in favor of [EntryPoint redirection](../../routing/entrypoints.md#redirection) or the [RedirectScheme middleware](./redirectscheme.md). | ||||
|  | ||||
| Set `sslTemporaryRedirect` to `true` to force an SSL redirection using a 302 (instead of a 301). | ||||
|  | ||||
| ### `sslHost` | ||||
|  | ||||
| !!! warning | ||||
|  | ||||
|     Deprecated in favor of the [RedirectRegex middleware](./redirectregex.md). | ||||
|  | ||||
| The `sslHost` option is the host name that is used to redirect HTTP requests to HTTPS. | ||||
|  | ||||
| ### `sslProxyHeaders` | ||||
|  | ||||
| The `sslProxyHeaders` option is set of header keys with associated values that would indicate a valid HTTPS request. | ||||
| It can be useful when using other proxies (example: `"X-Forwarded-Proto": "https"`). | ||||
|  | ||||
| ### `sslForceHost` | ||||
|  | ||||
| !!! warning | ||||
|  | ||||
|     Deprecated in favor of the [RedirectRegex middleware](./redirectregex.md). | ||||
|  | ||||
| Set `sslForceHost` to `true` and set `sslHost` to force requests to use `SSLHost` regardless of whether they already use SSL. | ||||
|  | ||||
| ### `stsSeconds` | ||||
|  | ||||
| The `stsSeconds` is the max-age of the `Strict-Transport-Security` header. | ||||
| @@ -452,14 +369,6 @@ The `publicKey` implements HPKP to prevent MITM attacks with forged certificates | ||||
|  | ||||
| The `referrerPolicy` allows sites to control whether browsers forward the `Referer` header to other sites. | ||||
|  | ||||
| ### `featurePolicy` | ||||
|  | ||||
| !!! warning | ||||
|  | ||||
|     Deprecated in favor of `permissionsPolicy` | ||||
|  | ||||
| The `featurePolicy` allows sites to control browser features. | ||||
|  | ||||
| ### `permissionsPolicy` | ||||
|  | ||||
| The `permissionsPolicy` allows sites to control browser features. | ||||
| @@ -469,3 +378,5 @@ The `permissionsPolicy` allows sites to control browser features. | ||||
| Set `isDevelopment` to `true` when developing to mitigate the unwanted effects of the `AllowedHosts`, SSL, and STS options. | ||||
| Usually testing takes place using HTTP, not HTTPS, and on `localhost`, not your production domain. | ||||
| If you would like your development environment to mimic production with complete Host blocking, SSL redirects, and STS headers, leave this as `false`. | ||||
|  | ||||
| {!traefik-for-business-applications.md!} | ||||
|   | ||||
| @@ -14,13 +14,13 @@ To proactively prevent services from being overwhelmed with high load, the numbe | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.amount=10" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-inflightreq | ||||
| @@ -34,18 +34,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-inflightreq.inflightreq.amount=10" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-inflightreq.inflightreq.amount": "10" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Limiting to 10 simultaneous connections | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.amount=10" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Limiting to 10 simultaneous connections | ||||
| http: | ||||
| @@ -69,13 +57,13 @@ http: | ||||
| The `amount` option defines the maximum amount of allowed simultaneous in-flight request. | ||||
| The middleware responds with `HTTP 429 Too Many Requests` if there are already `amount` requests in progress (based on the same `sourceCriterion` strategy). | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.amount=10" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-inflightreq | ||||
| @@ -89,18 +77,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-inflightreq.inflightreq.amount=10" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-inflightreq.inflightreq.amount": "10" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Limiting to 10 simultaneous connections | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.amount=10" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Limiting to 10 simultaneous connections | ||||
| http: | ||||
| @@ -127,6 +103,8 @@ If none are set, the default is to use the `requestHost`. | ||||
|  | ||||
| The `ipStrategy` option defines two parameters that configures how Traefik determines the client IP: `depth`, and `excludedIPs`. | ||||
|  | ||||
| !!! important "As a middleware, InFlightReq happens before the actual proxying to the backend takes place. In addition, the previous network hop only gets appended to `X-Forwarded-For` during the last stages of proxying, i.e. after it has already passed through the middleware. Therefore, during InFlightReq, as the previous network hop is not yet present in `X-Forwarded-For`, it cannot be used and/or relied upon." | ||||
|  | ||||
| ##### `ipStrategy.depth` | ||||
|  | ||||
| The `depth` option tells Traefik to use the `X-Forwarded-For` header and select the IP located at the `depth` position (starting from the right). | ||||
| @@ -144,13 +122,13 @@ The `depth` option tells Traefik to use the `X-Forwarded-For` header and select | ||||
|     | `"10.0.0.1,11.0.0.1,12.0.0.1,13.0.0.1"` | `3`     | `"11.0.0.1"` | | ||||
|     | `"10.0.0.1,11.0.0.1,12.0.0.1,13.0.0.1"` | `5`     | `""`         | | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.ipstrategy.depth=2" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-inflightreq | ||||
| @@ -165,17 +143,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.ipstrategy.depth=2" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.ipstrategy.depth": "2" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.ipstrategy.depth=2" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -209,13 +176,13 @@ http: | ||||
|     | `"10.0.0.1,11.0.0.1,12.0.0.1,13.0.0.1"` | `"15.0.0.1,16.0.0.1"` | `"13.0.0.1"` | | ||||
|     | `"10.0.0.1,11.0.0.1"`                   | `"10.0.0.1,11.0.0.1"` | `""`         | | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-inflightreq | ||||
| @@ -232,17 +199,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.ipstrategy.excludedips": "127.0.0.1/32, 192.168.1.7" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -266,13 +222,13 @@ http: | ||||
|  | ||||
| Name of the header used to group incoming requests. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.requestheadername=username" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-inflightreq | ||||
| @@ -286,17 +242,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.requestheadername=username" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.requestheadername": "username" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.requestheadername=username" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -317,13 +262,13 @@ http: | ||||
|  | ||||
| Whether to consider the request host as the source. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.requesthost=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-inflightreq | ||||
| @@ -337,17 +282,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.requesthost=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.requesthost": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-inflightreq.inflightreq.sourcecriterion.requesthost=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
|   | ||||
| @@ -1,32 +1,30 @@ | ||||
| --- | ||||
| title: "Traefik HTTP Middlewares IPWhiteList" | ||||
| description: "Learn how to use IPWhiteList in HTTP middleware for limiting clients to specific IPs in Traefik Proxy. Read the technical documentation." | ||||
| title: "Traefik HTTP Middlewares IPAllowList" | ||||
| description: "Learn how to use IPAllowList in HTTP middleware for limiting clients to specific IPs in Traefik Proxy. Read the technical documentation." | ||||
| --- | ||||
| 
 | ||||
| # IPWhiteList | ||||
| # IPAllowList | ||||
| 
 | ||||
| Limiting Clients to Specific IPs | ||||
| {: .subtitle } | ||||
| 
 | ||||
|  | ||||
| 
 | ||||
| IPWhitelist accepts / refuses requests based on the client IP. | ||||
| IPAllowList accepts / refuses requests based on the client IP. | ||||
| 
 | ||||
| ## Configuration Examples | ||||
| 
 | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Accepts request from defined IP | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
|   - "traefik.http.middlewares.test-ipallowlist.ipallowlist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ipwhitelist | ||||
|   name: test-ipallowlist | ||||
| spec: | ||||
|   ipWhiteList: | ||||
|   ipAllowList: | ||||
|     sourceRange: | ||||
|       - 127.0.0.1/32 | ||||
|       - 192.168.1.7 | ||||
| @@ -34,27 +32,15 @@ spec: | ||||
| 
 | ||||
| ```yaml tab="Consul Catalog" | ||||
| # Accepts request from defined IP | ||||
| - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
| 
 | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange": "127.0.0.1/32,192.168.1.7" | ||||
| } | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="Rancher" | ||||
| # Accepts request from defined IP | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| - "traefik.http.middlewares.test-ipallowlist.ipallowlist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="File (YAML)" | ||||
| # Accepts request from defined IP | ||||
| http: | ||||
|   middlewares: | ||||
|     test-ipwhitelist: | ||||
|       ipWhiteList: | ||||
|     test-ipallowlist: | ||||
|       ipAllowList: | ||||
|         sourceRange: | ||||
|           - "127.0.0.1/32" | ||||
|           - "192.168.1.7" | ||||
| @@ -63,7 +49,7 @@ http: | ||||
| ```toml tab="File (TOML)" | ||||
| # Accepts request from defined IP | ||||
| [http.middlewares] | ||||
|   [http.middlewares.test-ipwhitelist.ipWhiteList] | ||||
|   [http.middlewares.test-ipallowlist.ipAllowList] | ||||
|     sourceRange = ["127.0.0.1/32", "192.168.1.7"] | ||||
| ``` | ||||
| 
 | ||||
| @@ -75,7 +61,10 @@ The `sourceRange` option sets the allowed IPs (or ranges of allowed IPs by using | ||||
| 
 | ||||
| ### `ipStrategy` | ||||
| 
 | ||||
| The `ipStrategy` option defines two parameters that set how Traefik determines the client IP: `depth`, and `excludedIPs`. | ||||
| The `ipStrategy` option defines two parameters that set how Traefik determines the client IP: `depth`, and `excludedIPs`.   | ||||
| If no strategy is set, the default behavior is to match `sourceRange` against the Remote address found in the request. | ||||
| 
 | ||||
| !!! important "As a middleware, whitelisting happens before the actual proxying to the backend takes place. In addition, the previous network hop only gets appended to `X-Forwarded-For` during the last stages of proxying, i.e. after it has already passed through whitelisting. Therefore, during whitelisting, as the previous network hop is not yet present in `X-Forwarded-For`, it cannot be matched against `sourceRange`." | ||||
| 
 | ||||
| #### `ipStrategy.depth` | ||||
| 
 | ||||
| @@ -86,7 +75,7 @@ The `depth` option tells Traefik to use the `X-Forwarded-For` header and take th | ||||
| 
 | ||||
| !!! example "Examples of Depth & X-Forwarded-For" | ||||
| 
 | ||||
|     If `depth` is set to 2, and the request `X-Forwarded-For` header is `"10.0.0.1,11.0.0.1,12.0.0.1,13.0.0.1"` then the "real" client IP is `"10.0.0.1"` (at depth 4) but the IP used for the whitelisting is `"12.0.0.1"` (`depth=2`). | ||||
|     If `depth` is set to 2, and the request `X-Forwarded-For` header is `"10.0.0.1,11.0.0.1,12.0.0.1,13.0.0.1"` then the "real" client IP is `"10.0.0.1"` (at depth 4) but the IP used is `"12.0.0.1"` (`depth=2`). | ||||
| 
 | ||||
|     | `X-Forwarded-For`                       | `depth` | clientIP     | | ||||
|     |-----------------------------------------|---------|--------------| | ||||
| @@ -94,21 +83,21 @@ The `depth` option tells Traefik to use the `X-Forwarded-For` header and take th | ||||
|     | `"10.0.0.1,11.0.0.1,12.0.0.1,13.0.0.1"` | `3`     | `"11.0.0.1"` | | ||||
|     | `"10.0.0.1,11.0.0.1,12.0.0.1,13.0.0.1"` | `5`     | `""`         | | ||||
| 
 | ||||
| ```yaml tab="Docker" | ||||
| # Whitelisting Based on `X-Forwarded-For` with `depth=2` | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Allowlisting Based on `X-Forwarded-For` with `depth=2` | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
|   - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.depth=2" | ||||
|   - "traefik.http.middlewares.test-ipallowlist.ipallowlist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
|   - "traefik.http.middlewares.test-ipallowlist.ipallowlist.ipstrategy.depth=2" | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="Kubernetes" | ||||
| # Whitelisting Based on `X-Forwarded-For` with `depth=2` | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| # Allowlisting Based on `X-Forwarded-For` with `depth=2` | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ipwhitelist | ||||
|   name: test-ipallowlist | ||||
| spec: | ||||
|   ipWhiteList: | ||||
|   ipAllowList: | ||||
|     sourceRange: | ||||
|       - 127.0.0.1/32 | ||||
|       - 192.168.1.7 | ||||
| @@ -117,31 +106,17 @@ spec: | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="Consul Catalog" | ||||
| # Whitelisting Based on `X-Forwarded-For` with `depth=2` | ||||
| - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.depth=2" | ||||
| ``` | ||||
| 
 | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange": "127.0.0.1/32, 192.168.1.7", | ||||
|   "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.depth": "2" | ||||
| } | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="Rancher" | ||||
| # Whitelisting Based on `X-Forwarded-For` with `depth=2` | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
|   - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.depth=2" | ||||
| # Allowlisting Based on `X-Forwarded-For` with `depth=2` | ||||
| - "traefik.http.middlewares.test-ipallowlist.ipallowlist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| - "traefik.http.middlewares.test-ipallowlist.ipallowlist.ipstrategy.depth=2" | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="File (YAML)" | ||||
| # Whitelisting Based on `X-Forwarded-For` with `depth=2` | ||||
| # Allowlisting Based on `X-Forwarded-For` with `depth=2` | ||||
| http: | ||||
|   middlewares: | ||||
|     test-ipwhitelist: | ||||
|       ipWhiteList: | ||||
|     test-ipallowlist: | ||||
|       ipAllowList: | ||||
|         sourceRange: | ||||
|           - "127.0.0.1/32" | ||||
|           - "192.168.1.7" | ||||
| @@ -150,11 +125,11 @@ http: | ||||
| ``` | ||||
| 
 | ||||
| ```toml tab="File (TOML)" | ||||
| # Whitelisting Based on `X-Forwarded-For` with `depth=2` | ||||
| # Allowlisting Based on `X-Forwarded-For` with `depth=2` | ||||
| [http.middlewares] | ||||
|   [http.middlewares.test-ipwhitelist.ipWhiteList] | ||||
|   [http.middlewares.test-ipallowlist.ipAllowList] | ||||
|     sourceRange = ["127.0.0.1/32", "192.168.1.7"] | ||||
|     [http.middlewares.test-ipwhitelist.ipWhiteList.ipStrategy] | ||||
|     [http.middlewares.test-ipallowlist.ipAllowList.ipStrategy] | ||||
|       depth = 2 | ||||
| ``` | ||||
| 
 | ||||
| @@ -174,20 +149,20 @@ http: | ||||
|     | `"10.0.0.1,11.0.0.1,12.0.0.1,13.0.0.1"` | `"15.0.0.1,16.0.0.1"` | `"13.0.0.1"` | | ||||
|     | `"10.0.0.1,11.0.0.1"`                   | `"10.0.0.1,11.0.0.1"` | `""`         | | ||||
| 
 | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Exclude from `X-Forwarded-For` | ||||
| labels: | ||||
|     - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
|     - "traefik.http.middlewares.test-ipallowlist.ipallowlist.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="Kubernetes" | ||||
| # Exclude from `X-Forwarded-For` | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ipwhitelist | ||||
|   name: test-ipallowlist | ||||
| spec: | ||||
|   ipWhiteList: | ||||
|   ipAllowList: | ||||
|     ipStrategy: | ||||
|       excludedIPs: | ||||
|         - 127.0.0.1/32 | ||||
| @@ -196,27 +171,15 @@ spec: | ||||
| 
 | ||||
| ```yaml tab="Consul Catalog" | ||||
| # Exclude from `X-Forwarded-For` | ||||
| - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
| 
 | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.excludedips": "127.0.0.1/32, 192.168.1.7" | ||||
| } | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="Rancher" | ||||
| # Exclude from `X-Forwarded-For` | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ipwhitelist.ipwhitelist.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
| - "traefik.http.middlewares.test-ipallowlist.ipallowlist.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="File (YAML)" | ||||
| # Exclude from `X-Forwarded-For` | ||||
| http: | ||||
|   middlewares: | ||||
|     test-ipwhitelist: | ||||
|       ipWhiteList: | ||||
|     test-ipallowlist: | ||||
|       ipAllowList: | ||||
|         ipStrategy: | ||||
|           excludedIPs: | ||||
|             - "127.0.0.1/32" | ||||
| @@ -226,7 +189,7 @@ http: | ||||
| ```toml tab="File (TOML)" | ||||
| # Exclude from `X-Forwarded-For` | ||||
| [http.middlewares] | ||||
|   [http.middlewares.test-ipwhitelist.ipWhiteList] | ||||
|     [http.middlewares.test-ipwhitelist.ipWhiteList.ipStrategy] | ||||
|   [http.middlewares.test-ipallowlist.ipAllowList] | ||||
|     [http.middlewares.test-ipallowlist.ipAllowList.ipStrategy] | ||||
|       excludedIPs = ["127.0.0.1/32", "192.168.1.7"] | ||||
| ``` | ||||
| @@ -12,7 +12,7 @@ Controlling connections | ||||
|  | ||||
| ## Configuration Example | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # As a Docker Label | ||||
| whoami: | ||||
|   #  A container that exposes an API to show its IP address | ||||
| @@ -26,21 +26,8 @@ whoami: | ||||
|  | ||||
| ```yaml tab="Kubernetes IngressRoute" | ||||
| # As a Kubernetes Traefik IngressRoute | ||||
| apiVersion: apiextensions.k8s.io/v1beta1 | ||||
| kind: CustomResourceDefinition | ||||
| metadata: | ||||
|   name: middlewares.traefik.containo.us | ||||
| spec: | ||||
|   group: traefik.containo.us | ||||
|   version: v1alpha1 | ||||
|   names: | ||||
|     kind: Middleware | ||||
|     plural: middlewares | ||||
|     singular: middleware | ||||
|   scope: Namespaced | ||||
|  | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: stripprefix | ||||
| @@ -50,7 +37,7 @@ spec: | ||||
|       - /stripit | ||||
|  | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: IngressRoute | ||||
| metadata: | ||||
|   name: ingressroute | ||||
| @@ -69,22 +56,6 @@ spec: | ||||
| - "traefik.http.routers.router1.middlewares=foo-add-prefix@consulcatalog" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.foo-add-prefix.addprefix.prefix": "/foo", | ||||
|   "traefik.http.routers.router1.middlewares": "foo-add-prefix@marathon" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # As a Rancher Label | ||||
| labels: | ||||
|   # Create a middleware named `foo-add-prefix` | ||||
|   - "traefik.http.middlewares.foo-add-prefix.addprefix.prefix=/foo" | ||||
|   # Apply the middleware named `foo-add-prefix` to the router named `router1` | ||||
|   - "traefik.http.routers.router1.middlewares=foo-add-prefix@rancher" | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| # As TOML Configuration File | ||||
| [http.routers] | ||||
| @@ -142,7 +113,7 @@ http: | ||||
| | [Errors](errorpages.md)                   | Defines custom error pages                        | Request Lifecycle           | | ||||
| | [ForwardAuth](forwardauth.md)             | Delegates Authentication                          | Security, Authentication    | | ||||
| | [Headers](headers.md)                     | Adds / Updates headers                            | Security                    | | ||||
| | [IPWhiteList](ipwhitelist.md)             | Limits the allowed client IPs                     | Security, Request lifecycle | | ||||
| | [IPAllowList](ipallowlist.md)             | Limits the allowed client IPs                     | Security, Request lifecycle | | ||||
| | [InFlightReq](inflightreq.md)             | Limits the number of simultaneous connections     | Security, Request lifecycle | | ||||
| | [PassTLSClientCert](passtlsclientcert.md) | Adds Client Certificates in a Header              | Security                    | | ||||
| | [RateLimit](ratelimit.md)                 | Limits the call frequency                         | Security, Request lifecycle | | ||||
| @@ -153,3 +124,9 @@ http: | ||||
| | [Retry](retry.md)                         | Automatically retries in case of error            | Request lifecycle           | | ||||
| | [StripPrefix](stripprefix.md)             | Changes the path of the request                   | Path Modifier               | | ||||
| | [StripPrefixRegex](stripprefixregex.md)   | Changes the path of the request                   | Path Modifier               | | ||||
|  | ||||
| ## Community Middlewares | ||||
|  | ||||
| Please take a look at the community-contributed plugins in the [plugin catalog](https://plugins.traefik.io/plugins). | ||||
|  | ||||
| {!traefik-for-business-applications.md!} | ||||
|   | ||||
| @@ -16,16 +16,16 @@ PassTLSClientCert adds the selected data from the passed client TLS certificate | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header. | ||||
| Pass the pem in the `X-Forwarded-Tls-Client-Cert` header. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| # Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header. | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Pass the pem in the `X-Forwarded-Tls-Client-Cert` header. | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.pem=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-passtlsclientcert | ||||
| @@ -35,24 +35,12 @@ spec: | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Consul Catalog" | ||||
| # Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header | ||||
| # Pass the pem in the `X-Forwarded-Tls-Client-Cert` header | ||||
| - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.pem=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.pem": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header. | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.pem=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header. | ||||
| # Pass the pem in the `X-Forwarded-Tls-Client-Cert` header. | ||||
| http: | ||||
|   middlewares: | ||||
|     test-passtlsclientcert: | ||||
| @@ -61,15 +49,15 @@ http: | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| # Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header. | ||||
| # Pass the pem in the `X-Forwarded-Tls-Client-Cert` header. | ||||
| [http.middlewares] | ||||
|   [http.middlewares.test-passtlsclientcert.passTLSClientCert] | ||||
|     pem = true | ||||
| ``` | ||||
|  | ||||
| ??? example "Pass the escaped pem in the `X-Forwarded-Tls-Client-Cert` header" | ||||
| ??? example "Pass the pem in the `X-Forwarded-Tls-Client-Cert` header" | ||||
|  | ||||
|     ```yaml tab="Docker" | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     # Pass all the available info in the `X-Forwarded-Tls-Client-Cert-Info` header | ||||
|     labels: | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.notafter=true" | ||||
| @@ -95,7 +83,7 @@ http: | ||||
|  | ||||
|     ```yaml tab="Kubernetes" | ||||
|     # Pass all the available info in the `X-Forwarded-Tls-Client-Cert-Info` header | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: Middleware | ||||
|     metadata: | ||||
|       name: test-passtlsclientcert | ||||
| @@ -146,52 +134,6 @@ http: | ||||
|     - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.serialnumber=true" | ||||
|     ``` | ||||
|  | ||||
|     ```json tab="Marathon" | ||||
|     "labels": { | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.notafter": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.notbefore": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.sans": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.commonname": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.country": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.domaincomponent": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.locality": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.organization": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.organizationalunit": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.province": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.serialnumber": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.commonname": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.country": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.domaincomponent": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.locality": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.organization": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.province": "true", | ||||
|       "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.serialnumber": "true" | ||||
|     } | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="Rancher" | ||||
|     # Pass all the available info in the `X-Forwarded-Tls-Client-Cert-Info` header | ||||
|     labels: | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.notafter=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.notbefore=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.sans=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.commonname=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.country=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.domaincomponent=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.locality=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.organization=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.organizationalunit=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.province=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.subject.serialnumber=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.commonname=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.country=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.domaincomponent=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.locality=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.organization=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.province=true" | ||||
|       - "traefik.http.middlewares.test-passtlsclientcert.passtlsclientcert.info.issuer.serialnumber=true" | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="File (YAML)" | ||||
|     # Pass all the available info in the `X-Forwarded-Tls-Client-Cert-Info` header | ||||
|     http: | ||||
| @@ -254,12 +196,12 @@ http: | ||||
|  | ||||
| PassTLSClientCert can add two headers to the request: | ||||
|  | ||||
| - `X-Forwarded-Tls-Client-Cert` that contains the escaped pem. | ||||
| - `X-Forwarded-Tls-Client-Cert` that contains the pem. | ||||
| - `X-Forwarded-Tls-Client-Cert-Info` that contains all the selected certificate information in an escaped string. | ||||
|  | ||||
| !!! info | ||||
|  | ||||
|     * Each header value is a string that has been escaped in order to be a valid URL query. | ||||
|     * `X-Forwarded-Tls-Client-Cert-Info` header value is a string that has been escaped in order to be a valid URL query. | ||||
|     * These options only work accordingly to the [MutualTLS configuration](../../https/tls.md#client-authentication-mtls). | ||||
|     That is to say, only the certificates that match the `clientAuth.clientAuthType` policy are passed. | ||||
|  | ||||
| @@ -371,7 +313,7 @@ The following example shows a complete certificate and explains each of the midd | ||||
|  | ||||
| ### `pem` | ||||
|  | ||||
| The `pem` option sets the `X-Forwarded-Tls-Client-Cert` header with the escaped certificate. | ||||
| The `pem` option sets the `X-Forwarded-Tls-Client-Cert` header with the certificate. | ||||
|  | ||||
| In the example, it is the part between `-----BEGIN CERTIFICATE-----` and `-----END CERTIFICATE-----` delimiters: | ||||
|  | ||||
| @@ -445,6 +387,23 @@ Subject="DC=org,DC=cheese,C=FR,C=US,ST=Cheese org state,ST=Cheese com state,L=TO | ||||
|  | ||||
|     If there are more than one certificate, they are separated by a `,`. | ||||
|  | ||||
| #### `info.serialNumber` | ||||
|  | ||||
| Set the `info.serialNumber` option to `true` to add the `Serial Number` of the certificate. | ||||
|  | ||||
| The data is taken from the following certificate part: | ||||
|  | ||||
| ```text | ||||
| Serial Number: | ||||
|    6a:2f:20:f8:ce:8d:48:52:ba:d9:bb:be:60:ec:bf:79 | ||||
| ``` | ||||
|  | ||||
| And it is formatted as follows in the header (decimal representation): | ||||
|  | ||||
| ```text | ||||
| SerialNumber="141142874255168551917600297745052909433" | ||||
| ``` | ||||
|  | ||||
| #### `info.notAfter` | ||||
|  | ||||
| Set the `info.notAfter` option to `true` to add the `Not After` information from the `Validity` part. | ||||
| @@ -452,8 +411,8 @@ Set the `info.notAfter` option to `true` to add the `Not After` information from | ||||
| The data is taken from the following certificate part: | ||||
|  | ||||
| ```text | ||||
|     Validity | ||||
|         Not After : Dec  5 11:10:16 2020 GMT | ||||
| Validity | ||||
|     Not After : Dec  5 11:10:16 2020 GMT | ||||
| ``` | ||||
|  | ||||
| And it is formatted as follows in the header: | ||||
| @@ -486,8 +445,8 @@ Set the `info.sans` option to `true` to add the `Subject Alternative Name` infor | ||||
| The data is taken from the following certificate part: | ||||
|  | ||||
| ```text | ||||
|  X509v3 Subject Alternative Name: | ||||
|     DNS:*.example.org, DNS:*.example.net, DNS:*.example.com, IP Address:10.0.1.0, IP Address:10.0.1.2, email:test@example.org, email:test@example.net | ||||
| X509v3 Subject Alternative Name: | ||||
|    DNS:*.example.org, DNS:*.example.net, DNS:*.example.com, IP Address:10.0.1.0, IP Address:10.0.1.2, email:test@example.org, email:test@example.net | ||||
| ``` | ||||
|  | ||||
| And it is formatted as follows in the header: | ||||
|   | ||||
| @@ -10,9 +10,11 @@ To Control the Number of Requests Going to a Service | ||||
|  | ||||
| The RateLimit middleware ensures that services will receive a _fair_ amount of requests, and allows one to define what fair is. | ||||
|  | ||||
| It is based on a [token bucket](https://en.wikipedia.org/wiki/Token_bucket) implementation. In this analogy, the [average](#average) parameter (defined below) is the rate at which the bucket refills, and the [burst](#burst) is the size (volume) of the bucket. | ||||
|  | ||||
| ## Configuration Example | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Here, an average of 100 requests per second is allowed. | ||||
| # In addition, a burst of 50 requests is allowed. | ||||
| labels: | ||||
| @@ -23,7 +25,7 @@ labels: | ||||
| ```yaml tab="Kubernetes" | ||||
| # Here, an average of 100 requests per second is allowed. | ||||
| # In addition, a burst of 50 requests is allowed. | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ratelimit | ||||
| @@ -40,21 +42,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-ratelimit.ratelimit.burst=50" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ratelimit.ratelimit.average": "100", | ||||
|   "traefik.http.middlewares.test-ratelimit.ratelimit.burst": "50" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Here, an average of 100 requests per second is allowed. | ||||
| # In addition, a burst of 50 requests is allowed. | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.average=100" | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.burst=50" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Here, an average of 100 requests per second is allowed. | ||||
| # In addition, a burst of 50 requests is allowed. | ||||
| @@ -86,7 +73,7 @@ It defaults to `0`, which means no rate limiting. | ||||
| The rate is actually defined by dividing `average` by `period`. | ||||
| So for a rate below 1 req/s, one needs to define a `period` larger than a second. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # 100 reqs/s | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.average=100" | ||||
| @@ -94,7 +81,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # 100 reqs/s | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ratelimit | ||||
| @@ -108,17 +95,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-ratelimit.ratelimit.average=100" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ratelimit.ratelimit.average": "100", | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.average=100" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # 100 reqs/s | ||||
| http: | ||||
| @@ -145,7 +121,7 @@ r = average / period | ||||
|  | ||||
| It defaults to `1` second. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # 6 reqs/minute | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.average=6" | ||||
| @@ -154,7 +130,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # 6 reqs/minute | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ratelimit | ||||
| @@ -170,20 +146,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-ratelimit.ratelimit.period=1m" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ratelimit.ratelimit.average": "6", | ||||
|   "traefik.http.middlewares.test-ratelimit.ratelimit.period": "1m", | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # 6 reqs/minute | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.average=6" | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.period=1m" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # 6 reqs/minute | ||||
| http: | ||||
| @@ -208,13 +170,13 @@ http: | ||||
|  | ||||
| It defaults to `1`. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.burst=100" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ratelimit | ||||
| @@ -227,17 +189,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-ratelimit.ratelimit.burst=100" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ratelimit.ratelimit.burst": "100", | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.burst=100" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -262,6 +213,8 @@ If none are set, the default is to use the request's remote address field (as an | ||||
|  | ||||
| The `ipStrategy` option defines two parameters that configures how Traefik determines the client IP: `depth`, and `excludedIPs`. | ||||
|  | ||||
| !!! important "As a middleware, rate-limiting happens before the actual proxying to the backend takes place. In addition, the previous network hop only gets appended to `X-Forwarded-For` during the last stages of proxying, i.e. after it has already passed through rate-limiting. Therefore, during rate-limiting, as the previous network hop is not yet present in `X-Forwarded-For`, it cannot be found and/or relied upon." | ||||
|  | ||||
| ##### `ipStrategy.depth` | ||||
|  | ||||
| The `depth` option tells Traefik to use the `X-Forwarded-For` header and select the IP located at the `depth` position (starting from the right). | ||||
| @@ -279,13 +232,13 @@ The `depth` option tells Traefik to use the `X-Forwarded-For` header and select | ||||
|     | `"10.0.0.1,11.0.0.1,12.0.0.1,13.0.0.1"` | `3`     | `"11.0.0.1"` | | ||||
|     | `"10.0.0.1,11.0.0.1,12.0.0.1,13.0.0.1"` | `5`     | `""`         | | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.ipstrategy.depth=2" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ratelimit | ||||
| @@ -300,17 +253,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.ipstrategy.depth=2" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.ipstrategy.depth": "2" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.ipstrategy.depth=2" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -371,13 +313,13 @@ and the first IP that is _not_ in the pool (if any) is returned. | ||||
|     | `"10.0.0.1,11.0.0.1,13.0.0.1"` | `"15.0.0.1,16.0.0.1"` | `"13.0.0.1"` | | ||||
|     | `"10.0.0.1,11.0.0.1"`          | `"10.0.0.1,11.0.0.1"` | `""`         | | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ratelimit | ||||
| @@ -394,17 +336,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.ipstrategy.excludedips": "127.0.0.1/32, 192.168.1.7" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.ipstrategy.excludedips=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -428,13 +359,13 @@ http: | ||||
|  | ||||
| Name of the header used to group incoming requests. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.requestheadername=username" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ratelimit | ||||
| @@ -448,17 +379,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.requestheadername=username" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.requestheadername": "username" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.requestheadername=username" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
| @@ -479,13 +399,13 @@ http: | ||||
|  | ||||
| Whether to consider the request host as the source. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.requesthost=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-ratelimit | ||||
| @@ -499,17 +419,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.requesthost=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.requesthost": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-ratelimit.ratelimit.sourcecriterion.requesthost=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
|   | ||||
| @@ -16,7 +16,7 @@ The RedirectRegex redirects a request using regex matching and replacement. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Redirect with domain replacement | ||||
| # Note: all dollar signs need to be doubled for escaping. | ||||
| labels: | ||||
| @@ -26,7 +26,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Redirect with domain replacement | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-redirectregex | ||||
| @@ -43,21 +43,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-redirectregex.redirectregex.replacement=http://mydomain/$${1}" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-redirectregex.redirectregex.regex": "^http://localhost/(.*)", | ||||
|   "traefik.http.middlewares.test-redirectregex.redirectregex.replacement": "http://mydomain/${1}" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Redirect with domain replacement | ||||
| # Note: all dollar signs need to be doubled for escaping. | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-redirectregex.redirectregex.regex=^http://localhost/(.*)" | ||||
|   - "traefik.http.middlewares.test-redirectregex.redirectregex.replacement=http://mydomain/$${1}" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Redirect with domain replacement | ||||
| http: | ||||
|   | ||||
| @@ -12,11 +12,20 @@ Redirecting the Client to a Different Scheme/Port | ||||
| TODO: add schema | ||||
| --> | ||||
|  | ||||
| RedirectScheme redirects requests from a scheme/port to another. | ||||
| The RedirectScheme middleware redirects the request if the request scheme is different from the configured scheme. | ||||
|  | ||||
| !!! warning "When behind another reverse-proxy" | ||||
|  | ||||
|     When there is at least one other reverse-proxy between the client and Traefik,  | ||||
|     the other reverse-proxy (i.e. the last hop) needs to be a [trusted](../../routing/entrypoints.md#forwarded-headers) one.  | ||||
|      | ||||
|     Otherwise, Traefik would clean up the X-Forwarded headers coming from this last hop,  | ||||
|     and as the RedirectScheme middleware relies on them to determine the scheme used, | ||||
|     it would not function as intended. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Redirect to https | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.scheme=https" | ||||
| @@ -25,7 +34,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Redirect to https | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-redirectscheme | ||||
| @@ -42,20 +51,6 @@ labels: | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.permanent=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-redirectscheme.redirectscheme.scheme": "https" | ||||
|   "traefik.http.middlewares.test-redirectscheme.redirectscheme.permanent": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Redirect to https | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.scheme=https" | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.permanent=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Redirect to https | ||||
| http: | ||||
| @@ -80,7 +75,7 @@ http: | ||||
|  | ||||
| Set the `permanent` option to `true` to apply a permanent redirection. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Redirect to https | ||||
| labels: | ||||
|   # ... | ||||
| @@ -89,7 +84,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Redirect to https | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-redirectscheme | ||||
| @@ -106,20 +101,6 @@ labels: | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.permanent=true" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|  | ||||
|   "traefik.http.middlewares.test-redirectscheme.redirectscheme.permanent": "true" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Redirect to https | ||||
| labels: | ||||
|   # ... | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.permanent=true" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Redirect to https | ||||
| http: | ||||
| @@ -142,7 +123,7 @@ http: | ||||
|  | ||||
| The `scheme` option defines the scheme of the new URL. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Redirect to https | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.scheme=https" | ||||
| @@ -150,7 +131,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Redirect to https | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-redirectscheme | ||||
| @@ -165,18 +146,6 @@ labels: | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.scheme=https" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-redirectscheme.redirectscheme.scheme": "https" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Redirect to https | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.scheme=https" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Redirect to https | ||||
| http: | ||||
| @@ -197,7 +166,7 @@ http: | ||||
|  | ||||
| The `port` option defines the port of the new URL. | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Redirect to https | ||||
| labels: | ||||
|   # ... | ||||
| @@ -206,7 +175,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Redirect to https | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-redirectscheme | ||||
| @@ -223,20 +192,6 @@ labels: | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.port=443" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|  | ||||
|   "traefik.http.middlewares.test-redirectscheme.redirectscheme.port": "443" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Redirect to https | ||||
| labels: | ||||
|   # ... | ||||
|   - "traefik.http.middlewares.test-redirectscheme.redirectscheme.port=443" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Redirect to https | ||||
| http: | ||||
|   | ||||
| @@ -16,7 +16,7 @@ Replace the path of the request URL. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Replace the path with /foo | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-replacepath.replacepath.path=/foo" | ||||
| @@ -24,7 +24,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Replace the path with /foo | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-replacepath | ||||
| @@ -38,18 +38,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-replacepath.replacepath.path=/foo" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-replacepath.replacepath.path": "/foo" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Replace the path with /foo | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-replacepath.replacepath.path=/foo" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Replace the path with /foo | ||||
| http: | ||||
|   | ||||
| @@ -16,7 +16,7 @@ The ReplaceRegex replaces the path of a URL using regex matching and replacement | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Replace path with regex | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-replacepathregex.replacepathregex.regex=^/foo/(.*)" | ||||
| @@ -25,7 +25,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Replace path with regex | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-replacepathregex | ||||
| @@ -41,20 +41,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-replacepathregex.replacepathregex.replacement=/bar/$1" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-replacepathregex.replacepathregex.regex": "^/foo/(.*)", | ||||
|   "traefik.http.middlewares.test-replacepathregex.replacepathregex.replacement": "/bar/$1" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Replace path with regex | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-replacepathregex.replacepathregex.regex=^/foo/(.*)" | ||||
|   - "traefik.http.middlewares.test-replacepathregex.replacepathregex.replacement=/bar/$1" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Replace path with regex | ||||
| http: | ||||
|   | ||||
| @@ -18,7 +18,7 @@ The Retry middleware has an optional configuration to enable an exponential back | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Retry 4 times with exponential backoff | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-retry.retry.attempts=4" | ||||
| @@ -27,7 +27,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Retry 4 times with exponential backoff | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-retry | ||||
| @@ -43,20 +43,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-retry.retry.initialinterval=100ms" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-retry.retry.attempts": "4", | ||||
|   "traefik.http.middlewares.test-retry.retry.initialinterval": "100ms", | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Retry 4 times with exponential backoff | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-retry.retry.attempts=4" | ||||
|   - "traefik.http.middlewares.test-retry.retry.initialinterval=100ms" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Retry 4 times with exponential backoff | ||||
| http: | ||||
|   | ||||
| @@ -16,7 +16,7 @@ Remove the specified prefixes from the URL path. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Strip prefix /foobar and /fiibar | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-stripprefix.stripprefix.prefixes=/foobar,/fiibar" | ||||
| @@ -24,7 +24,7 @@ labels: | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| # Strip prefix /foobar and /fiibar | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-stripprefix | ||||
| @@ -40,18 +40,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-stripprefix.stripprefix.prefixes=/foobar,/fiibar" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-stripprefix.stripprefix.prefixes": "/foobar,/fiibar" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Strip prefix /foobar and /fiibar | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-stripprefix.stripprefix.prefixes=/foobar,/fiibar" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Strip prefix /foobar and /fiibar | ||||
| http: | ||||
| @@ -87,86 +75,4 @@ The `prefixes` option defines the prefixes to strip from the request URL. | ||||
| For instance, `/products` also matches `/products/shoes` and `/products/shirts`. | ||||
|  | ||||
| If your backend is serving assets (e.g., images or JavaScript files), it can use the `X-Forwarded-Prefix` header to properly construct relative URLs. | ||||
| Using the previous example, the backend should return `/products/shoes/image.png` (and not `/images.png`, which Traefik would likely not be able to associate with the same backend). | ||||
|  | ||||
| ### `forceSlash` | ||||
|  | ||||
| _Optional, Default=true_ | ||||
|  | ||||
| The `forceSlash` option ensures the resulting stripped path is not the empty string, by replacing it with `/` when necessary. | ||||
|  | ||||
| This option was added to keep the initial (non-intuitive) behavior of this middleware, in order to avoid introducing a breaking change. | ||||
|  | ||||
| It is recommended to explicitly set `forceSlash` to `false`. | ||||
|  | ||||
| ??? info "Behavior examples" | ||||
|  | ||||
|     - `forceSlash=true` | ||||
|  | ||||
|     | Path       | Prefix to strip | Result | | ||||
|     |------------|-----------------|--------| | ||||
|     | `/`        | `/`             | `/`    | | ||||
|     | `/foo`     | `/foo`          | `/`    | | ||||
|     | `/foo/`    | `/foo`          | `/`    | | ||||
|     | `/foo/`    | `/foo/`         | `/`    | | ||||
|     | `/bar`     | `/foo`          | `/bar` | | ||||
|     | `/foo/bar` | `/foo`          | `/bar` | | ||||
|  | ||||
|     - `forceSlash=false` | ||||
|  | ||||
|     | Path       | Prefix to strip | Result | | ||||
|     |------------|-----------------|--------| | ||||
|     | `/`        | `/`             | empty  | | ||||
|     | `/foo`     | `/foo`          | empty  | | ||||
|     | `/foo/`    | `/foo`          | `/`    | | ||||
|     | `/foo/`    | `/foo/`         | empty  | | ||||
|     | `/bar`     | `/foo`          | `/bar` | | ||||
|     | `/foo/bar` | `/foo`          | `/bar` | | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.example.stripprefix.prefixes=/foobar" | ||||
|   - "traefik.http.middlewares.example.stripprefix.forceSlash=false" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: example | ||||
| spec: | ||||
|   stripPrefix: | ||||
|     prefixes: | ||||
|       - "/foobar" | ||||
|     forceSlash: false | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.example.stripprefix.prefixes": "/foobar", | ||||
|   "traefik.http.middlewares.example.stripprefix.forceSlash": "false" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.example.stripprefix.prefixes=/foobar" | ||||
|   - "traefik.http.middlewares.example.stripprefix.forceSlash=false" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
|     example: | ||||
|       stripPrefix: | ||||
|         prefixes: | ||||
|           - "/foobar" | ||||
|         forceSlash: false | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [http.middlewares] | ||||
|   [http.middlewares.example.stripPrefix] | ||||
|     prefixes = ["/foobar"] | ||||
|     forceSlash = false | ||||
| ``` | ||||
| Using the previous example, the backend should return `/products/shoes/image.png` (and not `/image.png`, which Traefik would likely not be able to associate with the same backend). | ||||
|   | ||||
| @@ -12,13 +12,13 @@ Remove the matching prefixes from the URL path. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-stripprefixregex.stripprefixregex.regex=/foo/[a-z0-9]+/[0-9]+/" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: test-stripprefixregex | ||||
| @@ -32,17 +32,6 @@ spec: | ||||
| - "traefik.http.middlewares.test-stripprefixregex.stripprefixregex.regex=/foo/[a-z0-9]+/[0-9]+/" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.test-stripprefixregex.stripprefixregex.regex": "/foo/[a-z0-9]+/[0-9]+/" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| labels: | ||||
|   - "traefik.http.middlewares.test-stripprefixregex.stripprefixregex.regex=/foo/[a-z0-9]+/[0-9]+/" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| http: | ||||
|   middlewares: | ||||
|   | ||||
| @@ -23,7 +23,7 @@ Middlewares that use the same protocol can be combined into chains to fit every | ||||
|  | ||||
| ## Configuration Example | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # As a Docker Label | ||||
| whoami: | ||||
|   #  A container that exposes an API to show its IP address | ||||
| @@ -37,7 +37,7 @@ whoami: | ||||
|  | ||||
| ```yaml tab="Kubernetes IngressRoute" | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: Middleware | ||||
| metadata: | ||||
|   name: stripprefix | ||||
| @@ -47,7 +47,7 @@ spec: | ||||
|       - /stripit | ||||
|  | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: IngressRoute | ||||
| metadata: | ||||
|   name: ingressroute | ||||
| @@ -66,22 +66,6 @@ spec: | ||||
| - "traefik.http.routers.router1.middlewares=foo-add-prefix@consulcatalog" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.http.middlewares.foo-add-prefix.addprefix.prefix": "/foo", | ||||
|   "traefik.http.routers.router1.middlewares": "foo-add-prefix@marathon" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # As a Rancher Label | ||||
| labels: | ||||
|   # Create a middleware named `foo-add-prefix` | ||||
|   - "traefik.http.middlewares.foo-add-prefix.addprefix.prefix=/foo" | ||||
|   # Apply the middleware named `foo-add-prefix` to the router named `router1` | ||||
|   - "traefik.http.routers.router1.middlewares=foo-add-prefix@rancher" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # As YAML Configuration File | ||||
| http: | ||||
| @@ -129,3 +113,5 @@ http: | ||||
| A list of HTTP middlewares can be found [here](http/overview.md). | ||||
|  | ||||
| A list of TCP middlewares can be found [here](tcp/overview.md). | ||||
|  | ||||
| {!traefik-for-business-applications.md!} | ||||
|   | ||||
| @@ -7,13 +7,13 @@ To proactively prevent services from being overwhelmed with high load, the numbe | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| labels: | ||||
|   - "traefik.tcp.middlewares.test-inflightconn.inflightconn.amount=10" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: MiddlewareTCP | ||||
| metadata: | ||||
|   name: test-inflightconn | ||||
| @@ -27,18 +27,6 @@ spec: | ||||
| - "traefik.tcp.middlewares.test-inflightconn.inflightconn.amount=10" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.tcp.middlewares.test-inflightconn.inflightconn.amount": "10" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # Limiting to 10 simultaneous connections. | ||||
| labels: | ||||
|   - "traefik.tcp.middlewares.test-inflightconn.inflightconn.amount=10" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| # Limiting to 10 simultaneous connections. | ||||
| tcp: | ||||
|   | ||||
| @@ -1,30 +1,30 @@ | ||||
| --- | ||||
| title: "Traefik TCP Middlewares IPWhiteList" | ||||
| description: "Learn how to use IPWhiteList in TCP middleware for limiting clients to specific IPs in Traefik Proxy. Read the technical documentation." | ||||
| title: "Traefik TCP Middlewares IPAllowList" | ||||
| description: "Learn how to use IPAllowList in TCP middleware for limiting clients to specific IPs in Traefik Proxy. Read the technical documentation." | ||||
| --- | ||||
| 
 | ||||
| # IPWhiteList | ||||
| # IPAllowList | ||||
| 
 | ||||
| Limiting Clients to Specific IPs | ||||
| {: .subtitle } | ||||
| 
 | ||||
| IPWhitelist accepts / refuses connections based on the client IP. | ||||
| IPAllowList accepts / refuses connections based on the client IP. | ||||
| 
 | ||||
| ## Configuration Examples | ||||
| 
 | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # Accepts connections from defined IP | ||||
| labels: | ||||
|   - "traefik.tcp.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
|   - "traefik.tcp.middlewares.test-ipallowlist.ipallowlist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="Kubernetes" | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: MiddlewareTCP | ||||
| metadata: | ||||
|   name: test-ipwhitelist | ||||
|   name: test-ipallowlist | ||||
| spec: | ||||
|   ipWhiteList: | ||||
|   ipAllowList: | ||||
|     sourceRange: | ||||
|       - 127.0.0.1/32 | ||||
|       - 192.168.1.7 | ||||
| @@ -32,25 +32,13 @@ spec: | ||||
| 
 | ||||
| ```yaml tab="Consul Catalog" | ||||
| # Accepts request from defined IP | ||||
| - "traefik.tcp.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
| 
 | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.tcp.middlewares.test-ipwhitelist.ipwhitelist.sourcerange": "127.0.0.1/32,192.168.1.7" | ||||
| } | ||||
| ``` | ||||
| 
 | ||||
| ```yaml tab="Rancher" | ||||
| # Accepts request from defined IP | ||||
| labels: | ||||
|   - "traefik.tcp.middlewares.test-ipwhitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| - "traefik.tcp.middlewares.test-ipallowlist.ipallowlist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| ``` | ||||
| 
 | ||||
| ```toml tab="File (TOML)" | ||||
| # Accepts request from defined IP | ||||
| [tcp.middlewares] | ||||
|   [tcp.middlewares.test-ipwhitelist.ipWhiteList] | ||||
|   [tcp.middlewares.test-ipallowlist.ipAllowList] | ||||
|     sourceRange = ["127.0.0.1/32", "192.168.1.7"] | ||||
| ``` | ||||
| 
 | ||||
| @@ -58,8 +46,8 @@ labels: | ||||
| # Accepts request from defined IP | ||||
| tcp: | ||||
|   middlewares: | ||||
|     test-ipwhitelist: | ||||
|       ipWhiteList: | ||||
|     test-ipallowlist: | ||||
|       ipAllowList: | ||||
|         sourceRange: | ||||
|           - "127.0.0.1/32" | ||||
|           - "192.168.1.7" | ||||
| @@ -12,46 +12,33 @@ Controlling connections | ||||
|  | ||||
| ## Configuration Example | ||||
|  | ||||
| ```yaml tab="Docker" | ||||
| ```yaml tab="Docker & Swarm" | ||||
| # As a Docker Label | ||||
| whoami: | ||||
|   #  A container that exposes an API to show its IP address | ||||
|   image: traefik/whoami | ||||
|   labels: | ||||
|     # Create a middleware named `foo-ip-whitelist` | ||||
|     - "traefik.tcp.middlewares.foo-ip-whitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
|     # Apply the middleware named `foo-ip-whitelist` to the router named `router1` | ||||
|     - "traefik.tcp.routers.router1.middlewares=foo-ip-whitelist@docker" | ||||
|     # Create a middleware named `foo-ip-allowlist` | ||||
|     - "traefik.tcp.middlewares.foo-ip-allowlist.ipallowlist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
|     # Apply the middleware named `foo-ip-allowlist` to the router named `router1` | ||||
|     - "traefik.tcp.routers.router1.middlewares=foo-ip-allowlist@docker" | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Kubernetes IngressRoute" | ||||
| # As a Kubernetes Traefik IngressRoute | ||||
| apiVersion: apiextensions.k8s.io/v1beta1 | ||||
| kind: CustomResourceDefinition | ||||
| metadata: | ||||
|   name: middlewaretcps.traefik.containo.us | ||||
| spec: | ||||
|   group: traefik.containo.us | ||||
|   version: v1alpha1 | ||||
|   names: | ||||
|     kind: MiddlewareTCP | ||||
|     plural: middlewaretcps | ||||
|     singular: middlewaretcp | ||||
|   scope: Namespaced | ||||
|  | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: MiddlewareTCP | ||||
| metadata: | ||||
|   name: foo-ip-whitelist | ||||
|   name: foo-ip-allowlist | ||||
| spec: | ||||
|   ipWhiteList: | ||||
|   ipAllowList: | ||||
|     sourcerange: | ||||
|       - 127.0.0.1/32 | ||||
|       - 192.168.1.7 | ||||
|  | ||||
| --- | ||||
| apiVersion: traefik.containo.us/v1alpha1 | ||||
| apiVersion: traefik.io/v1alpha1 | ||||
| kind: IngressRouteTCP | ||||
| metadata: | ||||
|   name: ingressroute | ||||
| @@ -60,30 +47,14 @@ spec: | ||||
|   routes: | ||||
|     # more fields... | ||||
|     middlewares: | ||||
|       - name: foo-ip-whitelist | ||||
|       - name: foo-ip-allowlist | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Consul Catalog" | ||||
| # Create a middleware named `foo-ip-whitelist` | ||||
| - "traefik.tcp.middlewares.foo-ip-whitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| # Apply the middleware named `foo-ip-whitelist` to the router named `router1` | ||||
| - "traefik.tcp.routers.router1.middlewares=foo-ip-whitelist@consulcatalog" | ||||
| ``` | ||||
|  | ||||
| ```json tab="Marathon" | ||||
| "labels": { | ||||
|   "traefik.tcp.middlewares.foo-ip-whitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7", | ||||
|   "traefik.tcp.routers.router1.middlewares=foo-ip-whitelist@marathon" | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ```yaml tab="Rancher" | ||||
| # As a Rancher Label | ||||
| labels: | ||||
|   # Create a middleware named `foo-ip-whitelist` | ||||
|   - "traefik.tcp.middlewares.foo-ip-whitelist.ipwhitelist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
|   # Apply the middleware named `foo-ip-whitelist` to the router named `router1` | ||||
|   - "traefik.tcp.routers.router1.middlewares=foo-ip-whitelist@rancher" | ||||
| # Create a middleware named `foo-ip-allowlist` | ||||
| - "traefik.tcp.middlewares.foo-ip-allowlist.ipallowlist.sourcerange=127.0.0.1/32, 192.168.1.7" | ||||
| # Apply the middleware named `foo-ip-allowlist` to the router named `router1` | ||||
| - "traefik.tcp.routers.router1.middlewares=foo-ip-allowlist@consulcatalog" | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| @@ -91,11 +62,11 @@ labels: | ||||
| [tcp.routers] | ||||
|   [tcp.routers.router1] | ||||
|     service = "myService" | ||||
|     middlewares = ["foo-ip-whitelist"] | ||||
|     middlewares = ["foo-ip-allowlist"] | ||||
|     rule = "Host(`example.com`)" | ||||
|  | ||||
| [tcp.middlewares] | ||||
|   [tcp.middlewares.foo-ip-whitelist.ipWhiteList] | ||||
|   [tcp.middlewares.foo-ip-allowlist.ipAllowList] | ||||
|     sourceRange = ["127.0.0.1/32", "192.168.1.7"] | ||||
|  | ||||
| [tcp.services] | ||||
| @@ -114,12 +85,12 @@ tcp: | ||||
|     router1: | ||||
|       service: myService | ||||
|       middlewares: | ||||
|         - "foo-ip-whitelist" | ||||
|         - "foo-ip-allowlist" | ||||
|       rule: "Host(`example.com`)" | ||||
|  | ||||
|   middlewares: | ||||
|     foo-ip-whitelist: | ||||
|       ipWhiteList: | ||||
|     foo-ip-allowlist: | ||||
|       ipAllowList: | ||||
|         sourceRange: | ||||
|           - "127.0.0.1/32" | ||||
|           - "192.168.1.7" | ||||
| @@ -137,4 +108,4 @@ tcp: | ||||
| | Middleware                                | Purpose                                           | Area                        | | ||||
| |-------------------------------------------|---------------------------------------------------|-----------------------------| | ||||
| | [InFlightConn](inflightconn.md)           | Limits the number of simultaneous connections.    | Security, Request lifecycle | | ||||
| | [IPWhiteList](ipwhitelist.md)             | Limit the allowed client IPs.                     | Security, Request lifecycle | | ||||
| | [IPAllowList](ipallowlist.md)             | Limit the allowed client IPs.                     | Security, Request lifecycle | | ||||
|   | ||||
| @@ -38,7 +38,7 @@ Then any router can refer to an instance of the wanted middleware. | ||||
|  | ||||
|     !!! info "v1" | ||||
|  | ||||
|     ```yaml tab="Docker" | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     labels: | ||||
|       - "traefik.frontend.rule=Host:test.localhost;PathPrefix:/test" | ||||
|       - "traefik.frontend.auth.basic.users=test:$$apr1$$H6uskkkW$$IgXLP6ewTrSuBkTrqE8wj/,test2:$$apr1$$d9hr9HBB$$4HxwgUir3HP4EsggP/QNo0" | ||||
| @@ -100,7 +100,7 @@ Then any router can refer to an instance of the wanted middleware. | ||||
|  | ||||
|     !!! info "v2" | ||||
|  | ||||
|     ```yaml tab="Docker" | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     labels: | ||||
|       - "traefik.http.routers.router0.rule=Host(`test.localhost`) && PathPrefix(`/test`)" | ||||
|       - "traefik.http.routers.router0.middlewares=auth" | ||||
| @@ -109,8 +109,8 @@ Then any router can refer to an instance of the wanted middleware. | ||||
|  | ||||
|     ```yaml tab="K8s IngressRoute" | ||||
|     # The definitions below require the definitions for the Middleware and IngressRoute kinds. | ||||
|     # https://doc.traefik.io/traefik/v2.6/reference/dynamic-configuration/kubernetes-crd/#definitions | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     # https://doc.traefik.io/traefik/reference/dynamic-configuration/kubernetes-crd/#definitions | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: Middleware | ||||
|     metadata: | ||||
|       name: basicauth | ||||
| @@ -123,7 +123,7 @@ Then any router can refer to an instance of the wanted middleware. | ||||
|           - test2:$apr1$d9hr9HBB$4HxwgUir3HP4EsggP/QNo0 | ||||
|  | ||||
|     --- | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: IngressRoute | ||||
|     metadata: | ||||
|       name: ingressroutebar | ||||
| @@ -280,8 +280,8 @@ Then, a [router's TLS field](../routing/routers/index.md#tls) can refer to one o | ||||
|  | ||||
|     ```yaml tab="K8s IngressRoute" | ||||
|     # The definitions below require the definitions for the TLSOption and IngressRoute kinds. | ||||
|     # https://doc.traefik.io/traefik/v2.6/reference/dynamic-configuration/kubernetes-crd/#definitions | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     # https://doc.traefik.io/traefik/reference/dynamic-configuration/kubernetes-crd/#definitions | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: TLSOption | ||||
|     metadata: | ||||
|       name: mytlsoption | ||||
| @@ -297,7 +297,7 @@ Then, a [router's TLS field](../routing/routers/index.md#tls) can refer to one o | ||||
| 	    - TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 | ||||
|  | ||||
|     --- | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: IngressRoute | ||||
|     metadata: | ||||
|       name: ingressroutebar | ||||
| @@ -317,7 +317,7 @@ Then, a [router's TLS field](../routing/routers/index.md#tls) can refer to one o | ||||
|           namespace: default | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="Docker" | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     labels: | ||||
|       # myTLSOptions must be defined by another provider, in this instance in the File Provider. | ||||
|       # see the cross provider section | ||||
| @@ -428,7 +428,7 @@ To apply a redirection: | ||||
|  | ||||
|     !!! info "v2" | ||||
|  | ||||
|     ```yaml tab="Docker" | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     labels: | ||||
|       traefik.http.routers.app.rule: Host(`example.net`) | ||||
|       traefik.http.routers.app.entrypoints: web | ||||
| @@ -443,7 +443,7 @@ To apply a redirection: | ||||
|     ``` | ||||
|  | ||||
|     ```yaml tab="K8s IngressRoute" | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: IngressRoute | ||||
|     metadata: | ||||
|       name: http-redirect-ingressroute | ||||
| @@ -461,7 +461,7 @@ To apply a redirection: | ||||
|             - name: https-redirect | ||||
|  | ||||
|     --- | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: IngressRoute | ||||
|     metadata: | ||||
|       name: https-ingressroute | ||||
| @@ -478,7 +478,7 @@ To apply a redirection: | ||||
|       tls: {} | ||||
|  | ||||
|     --- | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: Middleware | ||||
|     metadata: | ||||
|       name: https-redirect | ||||
| @@ -556,7 +556,7 @@ with the path `/admin` stripped, e.g. to `http://<IP>:<port>/`. In this case, yo | ||||
|  | ||||
|     !!! info "v1" | ||||
|  | ||||
|     ```yaml tab="Docker" | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     labels: | ||||
|       - "traefik.frontend.rule=Host:example.org;PathPrefixStrip:/admin" | ||||
|     ``` | ||||
| @@ -588,7 +588,7 @@ with the path `/admin` stripped, e.g. to `http://<IP>:<port>/`. In this case, yo | ||||
|  | ||||
|     !!! info "v2" | ||||
|  | ||||
|     ```yaml tab="Docker" | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     labels: | ||||
|       - "traefik.http.routers.admin.rule=Host(`example.org`) && PathPrefix(`/admin`)" | ||||
|       - "traefik.http.routers.admin.middlewares=admin-stripprefix" | ||||
| @@ -597,7 +597,7 @@ with the path `/admin` stripped, e.g. to `http://<IP>:<port>/`. In this case, yo | ||||
|  | ||||
|     ```yaml tab="Kubernetes IngressRoute" | ||||
|     --- | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: IngressRoute | ||||
|     metadata: | ||||
|       name: http-redirect-ingressroute | ||||
| @@ -614,7 +614,7 @@ with the path `/admin` stripped, e.g. to `http://<IP>:<port>/`. In this case, yo | ||||
|           middlewares: | ||||
|             - name: admin-stripprefix | ||||
|     --- | ||||
|     apiVersion: traefik.containo.us/v1alpha1 | ||||
|     apiVersion: traefik.io/v1alpha1 | ||||
|     kind: Middleware | ||||
|     metadata: | ||||
|       name: admin-stripprefix | ||||
| @@ -1044,7 +1044,7 @@ To activate the dashboard, you can either: | ||||
|  | ||||
|     !!! info "v2" | ||||
|  | ||||
|     ```yaml tab="Docker" | ||||
|     ```yaml tab="Docker & Swarm" | ||||
|     # dynamic configuration | ||||
|     labels: | ||||
|       - "traefik.http.routers.api.rule=Host(`traefik.docker.localhost`)" | ||||
|   | ||||
							
								
								
									
										108
									
								
								docs/content/migration/v2-to-v3.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										108
									
								
								docs/content/migration/v2-to-v3.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,108 @@ | ||||
| --- | ||||
| title: "Traefik V3 Migration Documentation" | ||||
| description: "Migrate from Traefik Proxy v2 to v3 and update all the necessary configurations to take advantage of all the improvements. Read the technical documentation." | ||||
| --- | ||||
|  | ||||
| # Migration Guide: From v2 to v3 | ||||
|  | ||||
| How to Migrate from Traefik v2 to Traefik v3. | ||||
| {: .subtitle } | ||||
|  | ||||
| The version 3 of Traefik introduces a number of breaking changes, | ||||
| which require one to update their configuration when they migrate from v2 to v3. | ||||
| The goal of this page is to recapitulate all of these changes, and in particular to give examples, | ||||
| feature by feature, of how the configuration looked like in v2, and how it now looks like in v3. | ||||
|  | ||||
| ## IPWhiteList | ||||
|  | ||||
| In v3, we renamed the `IPWhiteList` middleware to `IPAllowList` without changing anything to the configuration.  | ||||
|  | ||||
| ## gRPC Metrics | ||||
|  | ||||
| In v3, the reported status code for gRPC requests is now the value of the `Grpc-Status` header.   | ||||
|  | ||||
| ## Deprecated Options Removal | ||||
|  | ||||
| - The `pilot` option has been removed from the static configuration. | ||||
| - The `tracing.datadog.globaltag` option has been removed. | ||||
| - The `namespace` option of Consul, Consul Catalog and Nomad providers has been removed. | ||||
| - The `tls.caOptional` option has been removed from the ForwardAuth middleware, as well as from the HTTP, Consul, Etcd, Redis, ZooKeeper, Consul Catalog, and Docker providers. | ||||
| - `sslRedirect`, `sslTemporaryRedirect`, `sslHost`, `sslForceHost` and `featurePolicy` options of the Headers middleware have been removed. | ||||
| - The `forceSlash` option of the StripPrefix middleware has been removed. | ||||
| - The `preferServerCipherSuites` option has been removed. | ||||
|  | ||||
| ## Matchers | ||||
|  | ||||
| In v3, the `Headers` and `HeadersRegexp` matchers have been renamed to `Header` and `HeaderRegexp` respectively. | ||||
|  | ||||
| `PathPrefix` no longer uses regular expressions to match path prefixes. | ||||
|  | ||||
| `QueryRegexp` has been introduced to match query values using a regular expression. | ||||
|  | ||||
| `HeaderRegexp`, `HostRegexp`, `PathRegexp`, `QueryRegexp`, and `HostSNIRegexp` matchers now uses the [Go regexp syntax](https://golang.org/pkg/regexp/syntax/). | ||||
|  | ||||
| All matchers now take a single value (except `Header`, `HeaderRegexp`, `Query`, and `QueryRegexp` which take two) | ||||
| and should be explicitly combined using logical operators to mimic previous behavior. | ||||
|  | ||||
| `Query` can take a single value to match is the query value that has no value (e.g. `/search?mobile`). | ||||
|  | ||||
| `HostHeader` has been removed, use `Host` instead. | ||||
|  | ||||
| ## Content-Type Auto-Detection | ||||
|  | ||||
| In v3, the `Content-Type` header is not auto-detected anymore when it is not set by the backend. | ||||
| One should use the `ContentType` middleware to enable the `Content-Type` header value auto-detection. | ||||
|  | ||||
| ## HTTP/3 | ||||
|  | ||||
| In v3, HTTP/3 is no longer an experimental feature. | ||||
| The `experimental.http3` option has been removed from the static configuration. | ||||
|  | ||||
| ## TCP ServersTransport | ||||
|  | ||||
| In v3, the support of `TCPServersTransport` has been introduced. | ||||
| When using the KubernetesCRD provider, it is therefore necessary to update [RBAC](../reference/dynamic-configuration/kubernetes-crd.md#rbac) and [CRD](../reference/dynamic-configuration/kubernetes-crd.md) manifests. | ||||
|  | ||||
| ### TCP LoadBalancer `terminationDelay` option | ||||
|  | ||||
| The TCP LoadBalancer `terminationDelay` option has been removed. | ||||
| This option can now be configured directly on the `TCPServersTransport` level, please take a look at this [documentation](../routing/services/index.md#terminationdelay) | ||||
|  | ||||
| ## Rancher v1 | ||||
|  | ||||
| In v3, the rancher v1 provider has been removed because Rancher v1 is [no longer actively maintaned](https://rancher.com/docs/os/v1.x/en/support/) and v2 is supported as a standard Kubernetes provider. | ||||
|  | ||||
| Rancher 2.x requires Kubernetes and does not have a metadata endpoint of its own for Traefik to query. | ||||
| As such, Rancher 2.x users should utilize the [Kubernetes CRD provider](../providers/kubernetes-crd.md) directly. | ||||
|  | ||||
| ## Marathon provider | ||||
|  | ||||
| In v3, the Marathon provider has been removed. | ||||
|  | ||||
| ## InfluxDB v1 | ||||
|  | ||||
| In v3, the InfluxDB v1 metrics provider has been removed because InfluxDB v1.x maintenance [ended in 2021](https://www.influxdata.com/blog/influxdb-oss-and-enterprise-roadmap-update-from-influxdays-emea/). | ||||
|  | ||||
| ### Kubernetes CRDs API Group `traefik.containo.us` | ||||
|  | ||||
| In v3, the Kubernetes CRDs API Group `traefik.containo.us` has been removed.  | ||||
| Please use the API Group `traefik.io` instead. | ||||
|  | ||||
| ## Docker & Docker Swarm | ||||
|  | ||||
| In v3, the provider Docker has been split into 2 providers: | ||||
|  | ||||
| - Docker provider (without Swarm support) | ||||
| - Swarm provider  (Swarm support only) | ||||
|  | ||||
| ### Kubernetes Ingress API Group `networking.k8s.io/v1beta1` | ||||
|  | ||||
| In v3, the Kubernetes Ingress API Group `networking.k8s.io/v1beta1` ([removed since Kubernetes v1.22](https://kubernetes.io/docs/reference/using-api/deprecation-guide/#ingress-v122)) support has been removed. | ||||
|  | ||||
| Please use the API Group `networking.k8s.io/v1` instead. | ||||
|  | ||||
| ### Traefik CRD API Version `apiextensions.k8s.io/v1beta1` | ||||
|  | ||||
| In v3, the Traefik CRD API Version `apiextensions.k8s.io/v1beta1` ([removed since Kubernetes v1.22](https://kubernetes.io/docs/reference/using-api/deprecation-guide/#customresourcedefinition-v122)) support has been removed. | ||||
|  | ||||
| Please use the CRD definition with the API Version `apiextensions.k8s.io/v1` instead. | ||||
| @@ -50,6 +50,7 @@ rules: | ||||
|       - watch | ||||
|   - apiGroups: | ||||
|       - extensions | ||||
|       - networking.k8s.io | ||||
|     resources: | ||||
|       - ingresses | ||||
|     verbs: | ||||
| @@ -58,18 +59,25 @@ rules: | ||||
|       - watch | ||||
|   - apiGroups: | ||||
|       - extensions | ||||
|       - networking.k8s.io | ||||
|     resources: | ||||
|       - ingresses/status | ||||
|     verbs: | ||||
|       - update | ||||
|   - apiGroups: | ||||
|       - traefik.io | ||||
|       - traefik.containo.us | ||||
|     resources: | ||||
|       - middlewares | ||||
|       - middlewaretcps | ||||
|       - ingressroutes | ||||
|       - traefikservices | ||||
|       - ingressroutetcps | ||||
|       - ingressrouteudps | ||||
|       - tlsoptions | ||||
|       - tlsstores | ||||
|       - serverstransports | ||||
|       - serverstransporttcps | ||||
|     verbs: | ||||
|       - get | ||||
|       - list | ||||
| @@ -147,6 +155,7 @@ rules: | ||||
|       - watch | ||||
|   - apiGroups: | ||||
|       - extensions | ||||
|       - networking.k8s.io | ||||
|     resources: | ||||
|       - ingresses | ||||
|     verbs: | ||||
| @@ -155,25 +164,29 @@ rules: | ||||
|       - watch | ||||
|   - apiGroups: | ||||
|       - extensions | ||||
|       - networking.k8s.io | ||||
|     resources: | ||||
|       - ingresses/status | ||||
|     verbs: | ||||
|       - update | ||||
|   - apiGroups: | ||||
|       - traefik.io | ||||
|       - traefik.containo.us | ||||
|     resources: | ||||
|       - middlewares | ||||
|       - middlewaretcps | ||||
|       - ingressroutes | ||||
|       - traefikservices | ||||
|       - ingressroutetcps | ||||
|       - ingressrouteudps | ||||
|       - tlsoptions | ||||
|       - tlsstores | ||||
|       - serverstransports | ||||
|       - serverstransporttcps | ||||
|     verbs: | ||||
|       - get | ||||
|       - list | ||||
|       - watch | ||||
|  | ||||
| ``` | ||||
|  | ||||
| After having both resources applied, Traefik will work properly. | ||||
| @@ -440,8 +453,8 @@ To enable HTTP/3 on an EntryPoint, please check out the [HTTP/3 configuration](. | ||||
|  | ||||
| ### Kubernetes Gateway API Provider | ||||
|  | ||||
| In `v2.6`, the [Kubernetes Gateway API provider](../providers/kubernetes-gateway.md) now only supports the version [v1alpha2](https://gateway-api.sigs.k8s.io/v1alpha2/guides/getting-started/) of the specification and  | ||||
| [route namespaces](https://gateway-api.sigs.k8s.io/v1alpha2/references/spec/#gateway.networking.k8s.io/v1alpha2.RouteNamespaces) selectors, which requires Traefik to fetch and watch the cluster namespaces. | ||||
| In `v2.6`, the [Kubernetes Gateway API provider](../providers/kubernetes-gateway.md) now only supports the version [v1alpha2](https://gateway-api.sigs.k8s.io/v1alpha2/guides/) of the specification and  | ||||
| [route namespaces](https://gateway-api.sigs.k8s.io/v1alpha2/references/spec/#gateway.networking.k8s.io/v1beta1.RouteNamespaces) selectors, which requires Traefik to fetch and watch the cluster namespaces. | ||||
| Therefore, the [RBAC](../reference/dynamic-configuration/kubernetes-gateway.md#rbac) and [CRD](../reference/dynamic-configuration/kubernetes-gateway.md#definitions) definitions must be updated. | ||||
|  | ||||
| ## v2.6.0 to v2.6.1 | ||||
| @@ -457,3 +470,59 @@ the value for the method label becomes `EXTENSION_METHOD`, instead of the reques | ||||
| ### Tracing | ||||
|  | ||||
| In `v2.6.1`, the Datadog tags added to a span changed from `service.name` to `traefik.service.name` and from `router.name` to `traefik.router.name`. | ||||
|  | ||||
| ## v2.8 | ||||
|  | ||||
| ### TLS client authentication | ||||
|  | ||||
| In `v2.8`, the `caOptional` option is deprecated as TLS client authentication is a server side option. | ||||
| This option available in the ForwardAuth middleware, as well as in the HTTP, Consul, Etcd, Redis, ZooKeeper, Marathon, Consul Catalog, and Docker providers has no effect and must not be used anymore. | ||||
|  | ||||
| ### Consul Enterprise Namespaces | ||||
|  | ||||
| In `v2.8`, the `namespace` option of Consul and Consul Catalog providers is deprecated, please use the `namespaces` options instead. | ||||
|  | ||||
| ### Traefik Pilot | ||||
|  | ||||
| In `v2.8`, the `pilot.token` and `pilot.dashboard` options are deprecated. | ||||
| Please check our Blog for migration instructions later this year. | ||||
|  | ||||
| ## v2.8.2 | ||||
|  | ||||
| Since `v2.5.0`, the `PreferServerCipherSuites` is [deprecated and ignored](https://tip.golang.org/doc/go1.17#crypto/tls) by Go, | ||||
| in `v2.8.2` the `preferServerCipherSuites` option is also deprecated and ignored in Traefik. | ||||
|  | ||||
| In `v2.8.2`, Traefik now reject certificates signed with the SHA-1 hash function. ([details](https://tip.golang.org/doc/go1.18#sha1)) | ||||
|  | ||||
| ## v2.9 | ||||
|  | ||||
| ### Traefik Pilot | ||||
|  | ||||
| In `v2.9`, Traefik Pilot support has been removed. | ||||
|  | ||||
| ## v2.10 | ||||
|  | ||||
| ### Nomad Namespace | ||||
|  | ||||
| In `v2.10`, the `namespace` option of the Nomad provider is deprecated, please use the `namespaces` options instead. | ||||
|  | ||||
| ### Kubernetes CRDs | ||||
|  | ||||
| In `v2.10`, the Kubernetes CRDs API Group `traefik.containo.us` is deprecated, and its support will end starting with Traefik v3. Please use the API Group `traefik.io` instead. | ||||
|  | ||||
| As the Kubernetes CRD provider still works with both API Versions (`traefik.io/v1alpha1` and `traefik.containo.us/v1alpha1`), | ||||
| it means that for the same kind, namespace and name, the provider will only keep the `traefik.io/v1alpha1` resource. | ||||
|  | ||||
| In addition, the Kubernetes CRDs API Version `traefik.io/v1alpha1` will not be supported in Traefik v3 itself. | ||||
|  | ||||
| Please note that it is a requirement to update the CRDs and the RBAC in the cluster before upgrading Traefik. | ||||
| To do so, please apply the required [CRDs](https://raw.githubusercontent.com/traefik/traefik/v2.10/docs/content/reference/dynamic-configuration/kubernetes-crd-definition-v1.yml) and [RBAC](https://raw.githubusercontent.com/traefik/traefik/v2.10/docs/content/reference/dynamic-configuration/kubernetes-crd-rbac.yml) manifests for v2.10: | ||||
|  | ||||
| ```bash | ||||
| kubectl apply -f https://raw.githubusercontent.com/traefik/traefik/v2.10/docs/content/reference/dynamic-configuration/kubernetes-crd-rbac.yml | ||||
| kubectl apply -f https://raw.githubusercontent.com/traefik/traefik/v2.10/docs/content/reference/dynamic-configuration/kubernetes-crd-definition-v1.yml | ||||
| ``` | ||||
|  | ||||
| ### Traefik Hub | ||||
|  | ||||
| In `v2.10`, Traefik Hub configuration has been removed because Traefik Hub v2 doesn't require this configuration. | ||||
|   | ||||
| @@ -154,9 +154,9 @@ accessLog: | ||||
|     headers: | ||||
|       defaultMode: keep | ||||
|       names: | ||||
|           User-Agent: redact | ||||
|           Authorization: drop | ||||
|           Content-Type: keep | ||||
|         User-Agent: redact | ||||
|         Authorization: drop | ||||
|         Content-Type: keep | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| @@ -229,6 +229,7 @@ accessLog: | ||||
|     | `RetryAttempts`         | The amount of attempts the request was retried.                                                                                                                     | | ||||
|     | `TLSVersion`            | The TLS version used by the connection (e.g. `1.2`) (if connection is TLS).                                                                                         | | ||||
|     | `TLSCipher`             | The TLS cipher used by the connection (e.g. `TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA`) (if connection is TLS)                                                           | | ||||
|     | `TLSClientSubject`      | The string representation of the TLS client certificate's Subject (e.g. `CN=username,O=organization`)                                                               | | ||||
|  | ||||
| ## Log Rotation | ||||
|  | ||||
| @@ -254,7 +255,7 @@ version: "3.7" | ||||
|  | ||||
| services: | ||||
|   traefik: | ||||
|     image: traefik:v2.6 | ||||
|     image: traefik:v3.0 | ||||
|     environment: | ||||
|       - TZ=US/Alaska | ||||
|     command: | ||||
|   | ||||
| @@ -64,7 +64,9 @@ log: | ||||
|  | ||||
| #### `level` | ||||
|  | ||||
| By default, the `level` is set to `ERROR`. Alternative logging levels are `DEBUG`, `PANIC`, `FATAL`, `ERROR`, `WARN`, and `INFO`. | ||||
| By default, the `level` is set to `ERROR`. | ||||
|  | ||||
| Alternative logging levels are `TRACE`, `DEBUG`, `INFO`, `WARN`, `ERROR`, `FATAL`, and `PANIC`. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| log: | ||||
| @@ -80,10 +82,101 @@ log: | ||||
| --log.level=DEBUG | ||||
| ``` | ||||
|  | ||||
| #### `noColor` | ||||
|  | ||||
| When using the 'common' format, disables the colorized output. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| log: | ||||
|   noColor: true | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [log] | ||||
|   noColor = true | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --log.nocolor=true | ||||
| ``` | ||||
|  | ||||
| ## Log Rotation | ||||
|  | ||||
| Traefik will close and reopen its log files, assuming they're configured, on receipt of a USR1 signal. | ||||
| This allows the logs to be rotated and processed by an external program, such as `logrotate`. | ||||
| The rotation of the log files can be configured with the following options. | ||||
|  | ||||
| !!! warning | ||||
|     This does not work on Windows due to the lack of USR signals. | ||||
| ### `maxSize` | ||||
|  | ||||
| `maxSize` is the maximum size in megabytes of the log file before it gets rotated. | ||||
| It defaults to 100 megabytes. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| log: | ||||
|   maxSize: 1 | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [log] | ||||
|   maxSize = 1 | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --log.maxsize=1 | ||||
| ``` | ||||
|  | ||||
| ### `maxBackups` | ||||
|  | ||||
| `maxBackups` is the maximum number of old log files to retain. | ||||
| The default is to retain all old log files (though `maxAge` may still cause them to get deleted). | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| log: | ||||
|   maxBackups: 3 | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [log] | ||||
|   maxBackups = 3 | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --log.maxbackups=3 | ||||
| ``` | ||||
|  | ||||
| ### `maxAge` | ||||
|  | ||||
| `maxAge` is the maximum number of days to retain old log files based on the timestamp encoded in their filename. | ||||
| Note that a day is defined as 24 hours and may not exactly correspond to calendar days due to daylight savings, leap seconds, etc. | ||||
| The default is not to remove old log files based on age. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| log: | ||||
|   maxAge: 3 | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [log] | ||||
|   maxAge = 3 | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --log.maxage=3 | ||||
| ``` | ||||
|  | ||||
| ### `compress` | ||||
|  | ||||
| `compress` determines if the rotated log files should be compressed using gzip. | ||||
| The default is not to perform compression. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| log: | ||||
|   compress: 3 | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [log] | ||||
|   compress = 3 | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --log.compress=3 | ||||
| ``` | ||||
|   | ||||
| @@ -1,268 +0,0 @@ | ||||
| --- | ||||
| title: "Traefik InfluxDB Documentation" | ||||
| description: "Traefik supports several metrics backends, including InfluxDB. Learn how to implement it for observability in Traefik Proxy. Read the technical documentation." | ||||
| --- | ||||
|  | ||||
| # InfluxDB | ||||
|  | ||||
| To enable the InfluxDB: | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: {} | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb=true | ||||
| ``` | ||||
|  | ||||
| #### `address` | ||||
|  | ||||
| _Required, Default="localhost:8089"_ | ||||
|  | ||||
| Address instructs exporter to send metrics to influxdb at this address. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     address: localhost:8089 | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     address = "localhost:8089" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.address=localhost:8089 | ||||
| ``` | ||||
|  | ||||
| #### `protocol` | ||||
|  | ||||
| _Required, Default="udp"_ | ||||
|  | ||||
| InfluxDB's address protocol (udp or http). | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     protocol: udp | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     protocol = "udp" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.protocol=udp | ||||
| ``` | ||||
|  | ||||
| #### `database` | ||||
|  | ||||
| _Optional, Default=""_ | ||||
|  | ||||
| InfluxDB database used when protocol is http. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     database: db | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     database = "db" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.database=db | ||||
| ``` | ||||
|  | ||||
| #### `retentionPolicy` | ||||
|  | ||||
| _Optional, Default=""_ | ||||
|  | ||||
| InfluxDB retention policy used when protocol is http. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     retentionPolicy: two_hours | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     retentionPolicy = "two_hours" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.retentionPolicy=two_hours | ||||
| ``` | ||||
|  | ||||
| #### `username` | ||||
|  | ||||
| _Optional, Default=""_ | ||||
|  | ||||
| InfluxDB username (only with http). | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     username: john | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     username = "john" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.username=john | ||||
| ``` | ||||
|  | ||||
| #### `password` | ||||
|  | ||||
| _Optional, Default=""_ | ||||
|  | ||||
| InfluxDB password (only with http). | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     password: secret | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     password = "secret" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.password=secret | ||||
| ``` | ||||
|  | ||||
| #### `addEntryPointsLabels` | ||||
|  | ||||
| _Optional, Default=true_ | ||||
|  | ||||
| Enable metrics on entry points. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     addEntryPointsLabels: true | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     addEntryPointsLabels = true | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.addEntryPointsLabels=true | ||||
| ``` | ||||
|  | ||||
| #### `addRoutersLabels` | ||||
|  | ||||
| _Optional, Default=false_ | ||||
|  | ||||
| Enable metrics on routers. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     addRoutersLabels: true | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     addRoutersLabels = true | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.addrouterslabels=true | ||||
| ``` | ||||
|  | ||||
| #### `addServicesLabels` | ||||
|  | ||||
| _Optional, Default=true_ | ||||
|  | ||||
| Enable metrics on services. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     addServicesLabels: true | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     addServicesLabels = true | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.addServicesLabels=true | ||||
| ``` | ||||
|  | ||||
| #### `pushInterval` | ||||
|  | ||||
| _Optional, Default=10s_ | ||||
|  | ||||
| The interval used by the exporter to push metrics to influxdb. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     pushInterval: 10s | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     pushInterval = "10s" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.pushInterval=10s | ||||
| ``` | ||||
|  | ||||
| #### `additionalLabels` | ||||
|  | ||||
| _Optional, Default={}_ | ||||
|  | ||||
| Additional labels (influxdb tags) on all metrics. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB: | ||||
|     additionalLabels: | ||||
|       host: example.com | ||||
|       environment: production | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB] | ||||
|     [metrics.influxDB.additionalLabels] | ||||
|       host = "example.com" | ||||
|       environment = "production" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb.additionallabels.host=example.com --metrics.influxdb.additionallabels.environment=production | ||||
| ``` | ||||
							
								
								
									
										219
									
								
								docs/content/observability/metrics/influxdb2.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										219
									
								
								docs/content/observability/metrics/influxdb2.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,219 @@ | ||||
| # InfluxDB v2 | ||||
|  | ||||
| To enable the InfluxDB2: | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB2: {} | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB2] | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb2=true | ||||
| ``` | ||||
|  | ||||
| #### `address` | ||||
|  | ||||
| _Required, Default="http://localhost:8086"_ | ||||
|  | ||||
| Address of the InfluxDB v2 instance. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB2: | ||||
|     address: http://localhost:8086 | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB2] | ||||
|     address = "http://localhost:8086" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb2.address=http://localhost:8086 | ||||
| ``` | ||||
|  | ||||
| #### `token` | ||||
|  | ||||
| _Required, Default=""_ | ||||
|  | ||||
| Token with which to connect to InfluxDB v2. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB2: | ||||
|     token: secret | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB2] | ||||
|     token = "secret" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb2.token=secret | ||||
| ``` | ||||
|  | ||||
| #### `org` | ||||
|  | ||||
| _Required, Default=""_ | ||||
|  | ||||
| Organisation where metrics will be stored. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB2: | ||||
|     org: my-org | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB2] | ||||
|     org = "my-org" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb2.org=my-org | ||||
| ``` | ||||
|  | ||||
| #### `bucket` | ||||
|  | ||||
| _Required, Default=""_ | ||||
|  | ||||
| Bucket where metrics will be stored. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB2: | ||||
|     bucket: my-bucket | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB2] | ||||
|     bucket = "my-bucket" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb2.bucket=my-bucket | ||||
| ``` | ||||
|  | ||||
| #### `addEntryPointsLabels` | ||||
|  | ||||
| _Optional, Default=true_ | ||||
|  | ||||
| Enable metrics on entry points. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB2: | ||||
|     addEntryPointsLabels: true | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB2] | ||||
|     addEntryPointsLabels = true | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb2.addEntryPointsLabels=true | ||||
| ``` | ||||
|  | ||||
| #### `addRoutersLabels` | ||||
|  | ||||
| _Optional, Default=false_ | ||||
|  | ||||
| Enable metrics on routers. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB2: | ||||
|     addRoutersLabels: true | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB2] | ||||
|     addRoutersLabels = true | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb2.addrouterslabels=true | ||||
| ``` | ||||
|  | ||||
| #### `addServicesLabels` | ||||
|  | ||||
| _Optional, Default=true_ | ||||
|  | ||||
| Enable metrics on services. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB2: | ||||
|     addServicesLabels: true | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB2] | ||||
|     addServicesLabels = true | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb2.addServicesLabels=true | ||||
| ``` | ||||
|  | ||||
| #### `pushInterval` | ||||
|  | ||||
| _Optional, Default=10s_ | ||||
|  | ||||
| The interval used by the exporter to push metrics to InfluxDB server. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB2: | ||||
|     pushInterval: 10s | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB2] | ||||
|     pushInterval = "10s" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb2.pushInterval=10s | ||||
| ``` | ||||
|  | ||||
| #### `additionalLabels` | ||||
|  | ||||
| _Optional, Default={}_ | ||||
|  | ||||
| Additional labels (InfluxDB tags) on all metrics. | ||||
|  | ||||
| ```yaml tab="File (YAML)" | ||||
| metrics: | ||||
|   influxDB2: | ||||
|     additionalLabels: | ||||
|       host: example.com | ||||
|       environment: production | ||||
| ``` | ||||
|  | ||||
| ```toml tab="File (TOML)" | ||||
| [metrics] | ||||
|   [metrics.influxDB2] | ||||
|     [metrics.influxDB2.additionalLabels] | ||||
|       host = "example.com" | ||||
|       environment = "production" | ||||
| ``` | ||||
|  | ||||
| ```bash tab="CLI" | ||||
| --metrics.influxdb2.additionallabels.host=example.com --metrics.influxdb2.additionallabels.environment=production | ||||
| ``` | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user