Compare commits

...

656 Commits

Author SHA1 Message Date
dependabot[bot]
7f9a567dc0 Bump ws from 5.2.2 to 5.2.3 in /spring-boot/thymeleaf-vue/client
Bumps [ws](https://github.com/websockets/ws) from 5.2.2 to 5.2.3.
- [Release notes](https://github.com/websockets/ws/releases)
- [Commits](https://github.com/websockets/ws/compare/5.2.2...5.2.3)

---
updated-dependencies:
- dependency-name: ws
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>
2022-12-04 22:51:50 +00:00
Arpendu Kumar Garai
cd69fa5842 code example for CSV Importer with Node
Co-authored-by: Arpendu Kumar Garai <Arpendu.KumarGarai@microfocus.com>
2022-12-05 09:50:13 +11:00
Arpendu Kumar Garai
3930e1cb03 Test and Automate Features behind the Flags using Cypress Tests (#206)
* nodejs cypress test launchdarkly

* Delete README.md

* refactor code

* refactor code

* code cleanup

Co-authored-by: Arpendu Kumar Garai <Arpendu.KumarGarai@microfocus.com>
2022-11-07 19:51:48 +11:00
Olaoluwa Ajibade
cd3e68cc66 Adding UrlShortener (#219) 2022-11-04 10:46:47 +11:00
ranjanih
06af47eb4b Spring CSRF (#223)
* Initial test commit

* Update UN PWD

* Updates

* Updates

* Updates

* Test updates

* Updates to tests

* Updates to code

* Update README

Co-authored-by: ranjani2412 <53815317+ranjani2412@users.noreply.github.com>
2022-10-21 10:41:40 +11:00
Arpendu Kumar Garai
f96a02270e Feature Flags in NodeJs React using LaunchDarkly (#205)
* nodejs react launchdarkly

* minor changes

* code refactor

* code refactor

Co-authored-by: Arpendu Kumar Garai <Arpendu.KumarGarai@microfocus.com>
2022-10-11 06:49:45 +11:00
Arpendu Kumar Garai
093221423e Feature Flags in Node.js Backend with LaunchDarkly (#204)
* nodejs-launchdarkly

* segregating code examples

* refactoring the code sections

* refactor directory name

* minor changes

* addressed review comments

* review comments

* review comments

Co-authored-by: Arpendu Kumar Garai <Arpendu.KumarGarai@microfocus.com>
2022-10-11 06:49:21 +11:00
ranjanih
d61382d459 Spring Boot timezones (#218)
* Files

* Updates to timezone-app

* Unit tests and config changes

* Review updates

* Updates to includes more asserts

* Remove sout

* Updates

Co-authored-by: ranjani2412 <53815317+ranjani2412@users.noreply.github.com>
2022-09-26 08:04:48 -05:00
Olaoluwa Ajibade
995a80b24b New Node-Job-Scheduler (#216) 2022-09-05 06:18:06 +10:00
ranjanih
52ce0d921f Configure cors with Spring (#209)
* Initial example

* Spring Webflux application

* Webflux filter

* Working samples

* Spring Web & Webflux initializr projects

* README updates

Co-authored-by: ranjani2412 <53815317+ranjani2412@users.noreply.github.com>
2022-09-01 06:46:01 +10:00
Olaoluwa Ajibade
126fa44d97 Adding NodeJs Logging CodeExamples (#199)
* Adding NodeJs Logging CodeExamples

* Adding NodeJs Logging CodeExamples
2022-07-25 09:51:25 +10:00
dzkaiten
b070b3376b Spring Cloud Tracing Demo Fixes (#188)
* Spring Cloud Tracing Demo Fixes

* Update docker-compose.yml
2022-07-15 06:37:56 +10:00
Anatolij Vasilev
a66b6a0aaa fixed broken link (#196)
The link in the readme was pointing to a 404 page
2022-07-15 06:36:55 +10:00
Abdulcelil Cercenazi
3d2be288e5 Code for Jackson post (#197)
* add the initial maven project

* add a few code examples

* add a few code examples

* add a few code examples

* add a few code examples

* add a few code examples

* add JsonAnyGetter example
2022-07-15 06:34:05 +10:00
Artur Kuksin
937fee0773 Merge pull request #195 from pratikdas/kotlin-coroutines
Kotlin Coroutines
2022-07-14 21:19:31 +02:00
Pratik Das
f531c21c67 code modified 2022-06-25 23:36:15 +05:30
Pratik Das
80165c55ab added code 2022-06-19 18:53:55 +05:30
Pratik Das
e4f9bece6b added code 2022-06-19 06:34:58 +05:30
Pratik Das
7f1cab6e0a added code 2022-06-19 06:13:02 +05:30
Tom Hombergs
351804a083 Update README.md 2022-06-08 17:56:24 +02:00
Arpendu Kumar Garai
657539d435 mapstruct guide (#192)
Co-authored-by: Arpendu Kumar Garai <Arpendu.KumarGarai@microfocus.com>
2022-06-08 17:55:58 +02:00
Artur Kuksin
f3064e5fa0 Merge pull request #190 from pratikdas/axios
Complete guide to Axios
2022-05-20 12:28:32 +02:00
Pratik Das
c6127955bd added ts code 2022-05-19 06:31:10 +05:30
ranjanih
2185f9c68d Introduction to retrofit (#185)
* Initial 3rd party library application

* Add basic auth to app and swagger-ui

* Modifications

* Audit application Initial commit

* Update README

* Application header changes

* Caching

* sync async requests

* Additional changes

* Unit tests

* Updates

* Mistaken refactoring

* Mistaken refactoring

* Mock updates

* Test updates

* Updates

Co-authored-by: ranjani2412 <53815317+ranjani2412@users.noreply.github.com>
2022-05-18 06:27:51 +10:00
Pratik Das
bd8c084a88 added code 2022-05-17 19:43:10 +05:30
Tom Hombergs
1d9c841d88 Update README.md 2022-05-08 06:46:22 +10:00
Artur Kuksin
ce10f21788 Merge pull request #184 from pratikdas/java-streams
Java streams
2022-05-05 11:37:53 +02:00
Artur Kuksin
8a7948a1b3 Merge branch 'master' into java-streams 2022-05-05 11:36:12 +02:00
Arpendu Kumar Garai
0372c85220 spring-reactive-architecture (#182)
Co-authored-by: Arpendu Kumar Garai <Arpendu.KumarGarai@microfocus.com>
2022-05-05 06:23:29 +10:00
Pratik Das
862b40b1fb Node errorhandling (#170)
* added code

* removed cdk code

* added code examples

* added ts files

* added code

* updated code

* error handling code

* Update nodejs/errorhandling/js/index.js

Co-authored-by: Pratik Das <pratikd2001@gmail.com>
Co-authored-by: Tom Hombergs <tom.hombergs@gmail.com>
2022-05-04 20:54:00 +10:00
Pratik Das
a5455521df added code 2022-04-29 21:11:59 +05:30
Pratik Das
89bd3b6729 added code 2022-04-29 21:08:35 +05:30
ranjanih
e2a0494de4 Code examples to support lombok (#171)
* Code examples to support lombok

* Examples

* Minor update

Co-authored-by: ranjani2412 <53815317+ranjani2412@users.noreply.github.com>
2022-04-10 08:55:31 +10:00
Pratik Das
a9bd712afe Merge branch 'node-errorhandling' of https://github.com/pratikdas/code-examples into node-errorhandling 2022-03-30 16:25:31 +05:30
Pratik Das
e1dae42a19 added readme for middleware article 2022-03-30 16:24:50 +05:30
Pratik Das
041442297e Merge branch 'master' into node-errorhandling 2022-03-30 11:04:29 +05:30
Pratik Das
2223be80c9 error handling code 2022-03-30 10:01:45 +05:30
Saikat Sengupta
1f37a81b90 Add code example for Spring Boot Application Info (#162)
* Add code example for Spring Boot Application Info

* Add relevant files
2022-03-28 08:33:11 +11:00
Pratik Das
c2145b5ece added code (#161)
Co-authored-by: Pratik Das <pratikd2001@gmail.com>
2022-03-26 15:52:58 +11:00
Tom Hombergs
c9c34a1d36 add maven wrapper 2022-03-21 10:30:45 +11:00
Tom Hombergs
3a95c4bd5e Merge remote-tracking branch 'origin/master'
# Conflicts:
#	spring-boot/beginners-guide/src/main/java/com/reflectoring/beginnersguide/BegginersGuideApplication.java
#	spring-boot/beginners-guide/src/main/java/com/reflectoring/beginnersguide/controllers/dto/BookResponse.java
#	spring-boot/beginners-guide/src/main/java/com/reflectoring/beginnersguide/domain/Book.java
#	spring-boot/beginners-guide/src/main/java/com/reflectoring/beginnersguide/repository/BookRepository.java
#	spring-boot/beginners-guide/src/main/java/com/reflectoring/beginnersguide/services/BookMapper.java
#	spring-boot/beginners-guide/src/main/java/com/reflectoring/beginnersguide/services/BorrowBookService.java
#	spring-boot/beginners-guide/src/main/java/com/reflectoring/beginnersguide/services/DeleteBookService.java
#	spring-boot/beginners-guide/src/main/java/com/reflectoring/beginnersguide/services/GetBookService.java
#	spring-boot/beginners-guide/src/main/java/com/reflectoring/beginnersguide/services/UpdateBookService.java
2022-03-21 09:46:45 +11:00
Tom Hombergs
b359ee9124 begginer -> beginner 2022-03-21 09:46:14 +11:00
Tom Hombergs
00acacedce Delete spring-boot/begginers-guide directory 2022-03-21 09:41:53 +11:00
Tom Hombergs
66b8191e10 begginer -> beginner 2022-03-21 09:40:47 +11:00
Mufa0
6f0c708d2f Added the code for the article (#152)
* Added the code for the article

* Added code for borrowing a book

Co-authored-by: Mateo Stjepanović <mateostjepanovic@Mateos-MacBook-Pro-2.local>
2022-03-21 09:33:50 +11:00
Pratik Das
385c8f7e96 updated code 2022-03-16 11:36:12 +05:30
Pratik Das
b2ab616af8 Aws kinesis (#160)
* added code

* removed cdk code

* added code examples

* added ts files

* added code

Co-authored-by: Pratik Das <pratikd2001@gmail.com>
2022-03-13 07:44:09 +11:00
Arpendu Kumar Garai
02c73d52f3 Getting started with Spring webflux (#155)
* spring webflux basic implementation

* Update application.yml

Co-authored-by: Arpendu Kumar Garai <Arpendu.KumarGarai@microfocus.com>
2022-03-10 06:45:26 +11:00
syedaf
c593aae6e1 Added Marker Annotation example (#148)
Added Marker Annotation example
2022-03-10 06:44:45 +11:00
Abdulcelil Cercenazi
50f24940fd add code for spring-shell post (#156)
* add code for spring-shell post

* update the build.gradle file
2022-03-10 06:41:58 +11:00
Pratik Das
a937ad3f96 Merge branch 'master' into aws-kinesis 2022-03-02 22:46:17 +05:30
Pratik Das
107586e6e5 added code 2022-03-02 22:36:19 +05:30
Robert Dey
7b3d79713c Nodejs module systems (#151)
* add code examples for nodejs modules

* add new cases for es modules

* add README
2022-02-18 06:25:06 +11:00
Tom Hombergs
00187368cb move node -> nodejs 2022-02-18 06:24:37 +11:00
Pratik Das
766bf4eda2 Express getting started (#147)
* added code

* removed cdk code

* added code examples

* added ts files

Co-authored-by: Pratik Das <pratikd2001@gmail.com>
Co-authored-by: Tom Hombergs <tom.hombergs@gmail.com>
2022-02-15 06:50:45 +11:00
Pratik Das
843bfe6ad9 Merge branch 'express-get-start' of https://github.com/pratikdas/code-examples into express-get-start 2022-02-13 22:32:33 +05:30
Pratik Das
de2d608c1d added ts files 2022-02-13 22:32:02 +05:30
Pratik Das
0d7b195e78 aws sqs (#141)
* added code

* removed cdk code

Co-authored-by: Pratik Das <pratikd2001@gmail.com>
Co-authored-by: Tom Hombergs <tom.hombergs@gmail.com>
2022-02-10 06:29:27 +11:00
Tom Hombergs
0de908ee78 Merge remote-tracking branch 'origin/master' 2022-02-05 11:45:37 +11:00
Tom Hombergs
8f09911a99 add maven wrapper 2022-02-05 11:45:32 +11:00
Tom Hombergs
972916ac7d Create README.md 2022-02-05 11:44:04 +11:00
Tom Hombergs
479a3cdb5b Merge remote-tracking branch 'origin/master' 2022-02-05 11:42:36 +11:00
Tom Hombergs
6b921c192d move annotation processor example 2022-02-05 11:42:30 +11:00
Tom Hombergs
2b1c0df8cf add module 7 2022-02-05 11:41:17 +11:00
syedaf
2b97cc155f Initial Commit (#142)
* Initial Commit

Added Maven Annotation Processor Demo project. Initial commit.

* Test - checking

* Delete test.rtf

* Initial commits

Initial commits for sample code

* Update SuppressWarningsDemo.java

* Code changes till SafeVarargs

Code changes till SafeVarargs

* Completed source code

Completed source code

* Final draft

Final draft version. Grammarly check done.

* Deleted java docs

Deleted java docs
2022-02-05 11:34:58 +11:00
Pratik Das
72cca1debc Merge branch 'master' into express-get-start 2022-02-03 22:57:33 +05:30
Pratik Das
6d122d285b added code examples 2022-02-03 22:55:10 +05:30
Saikat Sengupta
9d6f34dd98 Add code examples for Spring Boot nullsafety blog (#137)
* Add code examples for Spring Boot nullsafety blog

* Add required files as per checklist

* Add review comments

* Update build-all.sh

Co-authored-by: Tom Hombergs <tom.hombergs@gmail.com>
2022-02-01 06:43:37 +11:00
Pratik Das
aa952c0b18 removed cdk code 2022-01-27 20:24:12 +05:30
Pratik Das
98b3c96274 added code 2022-01-26 19:32:21 +05:30
Tom Hombergs
bbb40758ff Update README.md 2022-01-23 21:48:59 +11:00
Tom Hombergs
6a049565f6 Merge pull request #139 from pratikdas/cdknew
cdk v2
2022-01-23 21:48:31 +11:00
Pratik Das
0abe046a26 Merge branch 'cdknew' of https://github.com/pratikdas/code-examples into cdknew 2022-01-21 14:32:41 +05:30
Pratik Das
c78b0ab529 updated code 2022-01-21 14:32:20 +05:30
Pratik Das
799cc2f634 Merge branch 'master' into cdknew 2022-01-21 13:53:59 +05:30
Pratik Das
35514b4d94 updated build-all 2022-01-21 09:50:28 +05:30
Pratik Das
759c7b466a updated build-all 2022-01-21 09:18:34 +05:30
Pratik Das
940ae82360 added cdk code 2022-01-21 09:14:35 +05:30
Tom Hombergs
f3a5981709 Merge pull request #138 from Mufa0/immutables-library
Immutables library
2022-01-17 22:22:04 +11:00
Mateo Stjepanović
aa6af18246 Removed space to trigger build 2022-01-17 08:41:57 +01:00
Mateo Stjepanović
ef2c034fcc Merged build-all.sh from previous ones 2022-01-17 08:10:00 +01:00
Mateo Stjepanović
4951f762e8 Finished after code review and added into the build-all.sh script 2022-01-16 15:39:22 +01:00
Tom Hombergs
90b859c289 Merge pull request #135 from pratikdas/jCollect
Logical ops on collections
2022-01-15 13:18:45 +11:00
Tom Hombergs
d60dc3028d Merge remote-tracking branch 'origin/master' 2022-01-15 09:44:56 +11:00
Tom Hombergs
3c85af86a9 datetime based feature flags 2022-01-15 09:44:52 +11:00
Mateo Stjepanović
69a73d24cb Added new code for the article 2022-01-13 09:21:16 +01:00
Mateo Stjepanović
5d8237ff55 Added code examples for the article 2022-01-13 08:12:55 +01:00
Pratik Das
60275444ea added more methods 2022-01-12 05:07:48 +05:30
Tom Hombergs
9976bb40a7 Update README.md 2022-01-09 07:18:38 +11:00
Pratik Das
4f7a266d5b edits 2022-01-04 15:53:57 +05:30
Pratik Das
5f16d8b6e4 first commit 2022-01-04 15:25:55 +05:30
Tom Hombergs
e6fcc497ba Update README.md 2021-12-29 06:59:07 +11:00
Tom Hombergs
4196890615 Merge pull request #133 from pratikdas/resttemplate
resttemplate
2021-12-29 06:53:41 +11:00
Pratik Das
e152f99426 Merge branch 'resttemplate' of https://github.com/pratikdas/code-examples into resttemplate 2021-12-27 19:49:07 +05:30
Pratik Das
31c5e50424 edited restconsumer.java 2021-12-27 19:48:12 +05:30
Pratik Das
b0ed76a17c Merge branch 'master' into resttemplate 2021-12-27 09:35:00 +05:30
Pratik Das
451e92ee5e edited build-all 2021-12-27 09:28:26 +05:30
Pratik Das
557ec88beb added resttemplate code 2021-12-27 09:25:04 +05:30
Tom Hombergs
61b77ecb4b Merge pull request #130 from thombergs/tracing
Tracing
2021-12-27 05:58:29 +11:00
Tom Hombergs
31e9f97524 remove "clean" 2021-12-26 18:59:01 +11:00
Tom Hombergs
0b6178700e Merge remote-tracking branch 'origin/tracing' into tracing 2021-12-26 18:07:09 +11:00
Tom Hombergs
dac475644c Merge branch 'master' into tracing
# Conflicts:
#	build-all.sh
2021-12-26 18:06:58 +11:00
Tom Hombergs
c3ed0bbc04 Merge branch 'master' into tracing 2021-12-26 17:59:16 +11:00
Tom Hombergs
647db78e01 rafactor tracing example 2021-12-26 17:50:50 +11:00
Tom Hombergs
f935b37177 Merge pull request #125 from Mufa0/java-release-notes
Added code for article
2021-11-29 06:08:34 +11:00
Tom Hombergs
c21407a4c9 README 2021-11-25 20:49:23 +11:00
Tom Hombergs
876a79c856 README 2021-11-25 20:48:51 +11:00
Tom Hombergs
eadd7c34a5 README 2021-11-25 20:48:27 +11:00
Tom Hombergs
6aa921d29b migrate to Maven 2021-11-25 20:43:09 +11:00
Tom Hombergs
149ceab800 running Docker-Compose 2021-11-22 11:08:44 +11:00
Mufa0
c941e1786f Merge branch 'master' into java-release-notes 2021-11-21 14:14:22 +01:00
Mateo Stjepanović
b292d2b21d Reformating and changes for new version of article 2021-11-21 14:13:25 +01:00
Tom Hombergs
8b3fc268e7 Merge pull request #126 from pratikdas/java-hashes
java hashing code examples
2021-11-21 07:49:06 +11:00
thombergs
7b1f3dd12f remove modules from build 2021-11-21 07:17:33 +11:00
thombergs
d987fde764 remove modules from build 2021-11-21 07:15:04 +11:00
Mateo Stjepanović
889c55e957 Changes after article review 2021-11-20 12:55:50 +01:00
Pratik Das
ce4ad5edb7 added readme and buildall 2021-11-16 06:07:32 +05:30
Pratik Das
2283feeab8 added code examples 2021-11-16 05:59:24 +05:30
Mateo Stjepanović
7a154df18d Added new modules to build 2021-11-10 01:02:32 +01:00
Mateo Stjepanović
d2fcd379ad Added java-version propertiy 2021-11-10 00:57:25 +01:00
Mateo Stjepanović
e58eb0649f Changing target release 2021-11-10 00:51:22 +01:00
Mateo Stjepanović
5c5371b500 Added code for article 2021-11-10 00:43:09 +01:00
Tom Hombergs
903b344330 Merge pull request #124 from pratikdas/http-clients
Http clients code examples
2021-11-09 06:46:52 +11:00
Pratik Das
2ae82f9ecf Merge branch 'master' into http-clients 2021-11-05 17:21:26 +05:30
Pratik Das
7b98771339 updated readme and buildall 2021-11-05 17:19:02 +05:30
Pratik Das
908f53777d added code examples 2021-11-05 17:13:05 +05:30
Tom Hombergs
26a4ef6eb9 refactor tracing example 2021-11-03 10:51:47 +11:00
Tom Hombergs
37950f1a66 Merge pull request #123 from saajn/spring-resilience
Resilience4j TimeLimiter article
2021-10-24 08:06:24 +11:00
Saajan
c7937587fc Added article link to readme 2021-10-23 19:08:34 +05:30
Saajan
f46c7c7fa3 Initial check in 2021-10-23 18:48:50 +05:30
Tom Hombergs
e4d52aa182 example feature flag implementations 2021-10-20 07:09:53 +11:00
Tom Hombergs
7520c38d3e Merge pull request #115 from Mufa0/assertJ-article
Assert j article
2021-10-05 07:19:36 +11:00
Mateo Stjepanović
956f5a6570 Added this code to module and fixed what needed to be fixed so build runs successfully 2021-10-04 14:34:44 +02:00
Tom Hombergs
0ce5c7579e Merge pull request #119 from thombergs/feature-flag-patterns
Feature flag patterns
2021-10-03 09:44:55 +11:00
Tom Hombergs
d715f36b80 feature flag patterns 2021-10-03 09:39:55 +11:00
Pratik Das
e07f8b527f updated build-all 2021-09-30 22:58:39 +05:30
Pratik Das
1d11258019 added source code 2021-09-30 22:54:30 +05:30
Mateo Stjepanović
bba0174e0e Added new code for Method call extracting 2021-09-27 18:19:37 +02:00
Mateo Stjepanović
831b845398 Deleted unused tests from ExtractedPropertiesTests.java 2021-09-27 12:40:36 +02:00
Mateo Stjepanović
58273afb72 Deleted SoftAssertionTests.java since we don't use them 2021-09-27 08:11:17 +02:00
Mateo Stjepanović
3cf348e2d8 Removed target folder 2021-09-27 07:37:49 +02:00
Tom Hombergs
cf86383325 feature flag patterns 2021-09-26 09:06:46 +10:00
Mateo Stjepanović
bca7b37771 Added readme file 2021-09-20 12:47:40 +02:00
Mateo Stjepanović
3ffab95e8c Added code examples for AssertJ-article 2021-09-20 12:35:32 +02:00
Tom Hombergs
a09f5e7aa0 Merge pull request #113 from pratikdas/spring-scheduler
Spring-scheduler
2021-09-19 07:31:30 +10:00
Pratik Das
b72173ad27 updated build-all 2021-09-18 10:49:34 +05:30
Pratik Das
aac07331e8 added code for scheduler 2021-09-18 10:37:07 +05:30
Tom Hombergs
45590a81c2 Merge pull request #112 from pratikdas/spring-cloudwatch
added code for Spring boot CloudWatch
2021-09-07 07:21:54 +10:00
Pratik Das
1e39c49cca Merge branch 'spring-cloudwatch' of https://github.com/pratikdas/code-examples into spring-cloudwatch 2021-09-03 23:27:09 +05:30
Pratik Das
c8bd0660f5 added raedme 2021-09-03 23:26:39 +05:30
Pratik Das
2874daed69 Merge branch 'master' into spring-cloudwatch 2021-09-03 23:22:07 +05:30
Pratik Das
35a820acbb added code 2021-09-03 23:14:32 +05:30
Tom Hombergs
83e5e1048e Merge pull request #111 from saajn/spring-resilience
Code for Spring Boot Resilience4j RateLimiter article
2021-09-02 07:29:05 +10:00
Saajan
28147ad44c Merge branch 'master' of https://github.com/thombergs/code-examples into spring-resilience 2021-08-30 16:44:27 +05:30
Saajan
154453808d Initial commit of code for Spring Boot Resilience4j RateLimiter article 2021-08-30 16:43:47 +05:30
Tom Hombergs
b7139e9073 Merge pull request #105 from thombergs/structured-logging
code example for structured logging
2021-08-16 20:33:40 +10:00
Tom Hombergs
64499f5582 code example for structured logging 2021-08-16 20:22:15 +10:00
Tom Hombergs
c870f5dd4c Merge pull request #104 from thombergs/zero-downtime
Zero downtime
2021-08-04 06:53:08 +10:00
Tom Hombergs
946a9de553 Merge branch 'master' into zero-downtime
# Conflicts:
#	build-all.sh
2021-08-04 06:41:55 +10:00
Tom Hombergs
bf004661b0 zero-downtime example 2021-08-04 06:35:11 +10:00
Tom Hombergs
9cb21ffb8a zero-downtime example 2021-08-04 06:33:55 +10:00
Tom Hombergs
375928575c zero-downtime example 2021-08-04 06:33:14 +10:00
Tom Hombergs
36a5bdda1e Merge pull request #102 from pratikdas/csrf
CSRF Code examples
2021-07-31 12:37:06 +10:00
Tom Hombergs
d0b88ace16 .properties -> .yml 2021-07-24 06:51:49 +10:00
Tom Hombergs
2e74db8684 wip 2021-07-24 06:44:33 +10:00
Tom Hombergs
597844a483 Merge pull request #101 from saajn/spring-resilience
Examples for the Spring Boot Resilience4j article
2021-07-24 06:22:35 +10:00
Pratik Das
3c934fd394 added code 2021-07-22 15:14:26 +05:30
Saajan
c66d4bd7d7 Added readme file and updated build-all 2021-07-21 15:41:06 +05:30
Saajan
5deb6fb09c Initial commit 2021-07-21 15:34:24 +05:30
Tom Hombergs
55dfc429cb remove snapshot dependency 2021-07-18 10:56:49 +10:00
Tom Hombergs
5a9e2751db Merge remote-tracking branch 'origin/master' 2021-07-18 10:47:30 +10:00
Tom Hombergs
9e6f17cf1e remove snapshot dependency 2021-07-18 10:47:25 +10:00
Tom Hombergs
e7c95ea2e4 Merge pull request #99 from pratikdas/cors
cors
2021-07-18 10:19:09 +10:00
Tom Hombergs
16815980a9 Merge remote-tracking branch 'origin/master'
# Conflicts:
#	spring-boot/feature-flags/.mvn/wrapper/MavenWrapperDownloader.java
#	spring-boot/feature-flags/.mvn/wrapper/maven-wrapper.properties
2021-07-17 07:06:33 +10:00
Tom Hombergs
d49982299d add Maven Wrapper 2021-07-17 07:06:23 +10:00
Tom Hombergs
cf7ecd5f4f zero-downtime example 2021-07-17 07:05:13 +10:00
Pratik Das
406a57d203 added code 2021-07-05 18:09:25 +05:30
Tom Hombergs
a0c58111ec Merge pull request #98 from thombergs/feature-flags
feature flags
2021-07-04 10:03:32 +10:00
Tom Hombergs
355ceb2517 Merge remote-tracking branch 'origin/feature-flags' into feature-flags 2021-07-04 09:58:49 +10:00
Tom Hombergs
c4d2d74f70 add maven wrapper 2021-07-04 09:58:43 +10:00
Tom Hombergs
058bf95ed6 Merge branch 'master' into feature-flags 2021-07-04 09:53:29 +10:00
Tom Hombergs
adf0b55548 feature flags 2021-07-03 07:56:18 +10:00
Tom Hombergs
7b76a8a562 Merge pull request #97 from pratikdas/spring-ses
Spring cloud ses
2021-06-27 08:11:56 +10:00
Tom Hombergs
f6501aff2c Merge branch 'master' into spring-ses 2021-06-27 08:09:48 +10:00
Tom Hombergs
0101fc58f0 Merge pull request #93 from murtuza-ranapur/spring-redis-cache
Caching with Spring Cloud AWS and ElastiCache
2021-06-27 07:25:30 +10:00
Tom Hombergs
36e25d3b7e Merge branch 'master' into spring-redis-cache 2021-06-27 07:16:21 +10:00
Pratik Das
c36ad11f17 build-all updated 2021-06-23 15:16:55 +04:00
Pratik Das
a19a7faf43 added ses code 2021-06-23 15:11:49 +04:00
Tom Hombergs
9f8e3f3bd5 Merge pull request #96 from pratikdas/spring-camel
Spring camel
2021-06-21 08:57:13 +10:00
Murtuza Ranapur
6784d3c31f Merge branch 'master' into spring-redis-cache 2021-06-20 21:22:58 +05:30
Murtuza Ranapurwala
8a253fe371 Move project to aws folder 2021-06-20 14:28:21 +05:30
Pratik Das
03517e3037 updated Readme 2021-06-13 16:47:57 +04:00
Pratik Das
ec71062edb added Readme 2021-06-13 16:44:42 +04:00
Pratik Das
8d82de705f added code 2021-06-13 15:10:52 +04:00
Tom Hombergs
84f58908ed Merge pull request #94 from pratikdas/aws-spring-dynamodb
Dynamodb with spring code examples
2021-06-13 07:25:21 +10:00
Murtuza Ranapurwala
6042b5c086 Adds Spring Cloud AWS for caching 2021-06-06 21:31:26 +05:30
Tom Hombergs
0eaea89433 logging examples 2021-06-06 19:54:33 +10:00
Pratik Das
cca9825c1c updates repository and test 2021-06-05 15:30:12 +04:00
Pratik Das
59747d5a60 edited readme 2021-06-05 15:26:52 +04:00
Pratik Das
3883b0b337 edited readme 2021-06-05 15:18:38 +04:00
Pratik Das
c41d61f17a added readme 2021-06-05 15:15:28 +04:00
Tom Hombergs
f9bde4b1e2 add maven wrapper 2021-06-05 15:55:01 +10:00
Tom Hombergs
5168068e7f logback example 2021-06-05 15:53:18 +10:00
Tom Hombergs
d2acf47492 add logback example project 2021-06-05 15:51:16 +10:00
Tom Hombergs
b8358fc949 add maven wrapper 2021-06-05 07:54:53 +10:00
Tom Hombergs
52c92afd68 add maven wrapper 2021-06-05 07:53:51 +10:00
Tom Hombergs
bb4cd9e297 Merge remote-tracking branch 'origin/master'
# Conflicts:
#	build-all.sh
2021-06-05 07:51:33 +10:00
Tom Hombergs
0a37bcbba9 add log4j example 2021-06-05 07:50:27 +10:00
Pratik Das
64c61b74e4 Merge branch 'aws-spring-dynamodb' of https://github.com/pratikdas/code-examples into aws-spring-dynamodb 2021-06-03 13:12:57 +04:00
Pratik Das
58cd6f04dd renamed folder 2021-06-03 13:08:57 +04:00
Pratik Das
78610bb86b Merge branch 'master' into aws-spring-dynamodb 2021-06-03 12:32:49 +04:00
Pratik Das
cb69d89ca5 updated build-all 2021-06-03 12:29:44 +04:00
Pratik Das
88f18e1d3d added code for 2 modules 2021-06-03 12:24:06 +04:00
Murtuza Ranapurwala
10e8867d4b Adds README.md 2021-05-31 20:35:41 +05:30
Murtuza Ranapurwala
d66a38943f Initial commit 2021-05-31 20:28:31 +05:30
Tom Hombergs
18a6de19d4 Merge pull request #85 from cbenaveen/spring-boot-testconfiguration-code-example
TestConfiguration implementation example
2021-05-28 06:41:18 +10:00
Tom Hombergs
b2c67f3d10 Merge branch 'master' into spring-boot-testconfiguration-code-example 2021-05-28 06:34:55 +10:00
Tom Hombergs
a359a8d3f2 Merge pull request #83 from pratikdas/aws-spring-cloud-rds
added code for spring cloud jdbc for aws rds
2021-05-25 06:45:04 +10:00
Pratik Das
273111b0c6 removed jdbc 2021-05-21 15:51:24 +04:00
K. Naveen Kumar
46fe09352e Removed all Sysout's instead using SLF4J logger 2021-05-20 21:21:04 +05:30
K. Naveen Kumar
ab79a6be97 Changes: 1) Remove spring boot actuator dependency 2) Renamed a static inner class to WebClientTestConfiguration in UsingStaticInnerTestConfiguration.jav 3) Added spring-boot/spring-boot-testconfiguration to build-all.sh file 2021-05-20 21:10:36 +05:30
K. Naveen Kumar
c4a70d8865 TestConfiguration implementation example that is accompanies Test Configuration blog post 2021-05-15 13:24:23 +05:30
Pratik Das
bcd975e02f added rds code 2021-05-13 16:08:18 +04:00
Pratik Das
7fd1bdc29f added rds code 2021-05-13 15:56:32 +04:00
Tom Hombergs
4b69588894 Merge pull request #82 from pratikdas/aws-spring-cloud-messaging
code example aws-spring-cloud-messaging
2021-05-10 07:04:59 +10:00
Tom Hombergs
88936def38 Merge pull request #79 from pratikdas/patch-1
Update README.md to correct spelling of AWS
2021-05-08 07:24:59 +10:00
Tom Hombergs
caf96dd931 Merge pull request #78 from pratikdas/thread-dump-analyzer
Thread dump analyzer
2021-05-05 06:56:13 +10:00
Pratik Das
6b13e04aea Merge branch 'master' into aws-spring-cloud-messaging 2021-05-01 20:47:18 +04:00
Pratik Das
a9795c3298 modified build-all 2021-05-01 20:31:49 +04:00
Pratik Das
ecb2634a77 modified pom 2021-05-01 18:48:25 +04:00
Pratik Das
237a5a6441 added readme 2021-05-01 18:30:59 +04:00
Pratik Das
674d4feb17 code example aws-spring-cloud-messaging 2021-05-01 18:26:28 +04:00
Tom Hombergs
610906f891 Merge pull request #80 from saajn/actuator2
Examples for the Actuator article
2021-04-30 07:16:36 +10:00
Tom Hombergs
258f7fb137 Merge branch 'master' into actuator2 2021-04-30 07:05:14 +10:00
Tom Hombergs
475ef47881 Merge pull request #77 from silenum/feature/clean-unit-tests-with-mockito
added code examples for clean unit tests with mockito
2021-04-25 10:35:17 +10:00
Saajan
39c28dddf0 Moved the counter 2021-04-24 20:24:25 +05:30
Saajan
2b8664e49e Added module to build-all 2021-04-24 19:56:12 +05:30
Saajan
d0c5706133 Initial check in 2021-04-24 19:43:07 +05:30
Pratik Das
cd45701470 Update README.md
Important::Correction in the spelling of AWS.
2021-04-22 05:24:29 +04:00
Tom Hombergs
070ad968e6 Merge pull request #76 from pratikdas/aws-terraform
updated git ignore to exclude DS-Store and uploaded Terraform aws source
2021-04-21 07:57:15 +10:00
Pratik Das
c29993b416 thread dump example 2021-04-20 18:17:31 +04:00
Pratik Das
a481a48992 thread dump example 2021-04-20 18:05:48 +04:00
Pratik Das
3be0e85a77 thread dumo example 2021-04-20 17:46:27 +04:00
Lukas Leuenberger
973cb7a081 updated build-all.sh for mockito 2021-04-20 00:02:06 +02:00
Lukas Leuenberger
33dacb36de added code examples for clean unit tests with mockito 2021-04-20 00:02:06 +02:00
Pratik Das
aaa07d4c70 added README 2021-04-16 16:24:21 +04:00
Pratik Das
23cd4e4da7 updated git ignore 2021-04-16 16:01:29 +04:00
Tom Hombergs
43b9c83917 Merge pull request #74 from bakic/service-provider-interface
Service Provider Interface
2021-03-26 07:33:29 +11:00
Abdelbaki BEN ELHAJ SLIMENE
b558643405 review changes 2021-03-24 16:21:16 +01:00
Tom Hombergs
acdf98e71b Merge pull request #67 from thombergs/dependabot/npm_and_yarn/pact/pact-react-consumer/axios-0.21.1
Bump axios from 0.18.0 to 0.21.1 in /pact/pact-react-consumer
2021-03-24 06:36:33 +11:00
Abdelbaki BEN ELHAJ SLIMENE
c30b27b240 Service Provider Interface 2021-03-14 21:26:24 +01:00
Tom Hombergs
dbdd4d20cb update testcontainers to hopefully fix CI issue 2021-02-18 06:37:43 +11:00
Tom Hombergs
379f0d6799 Merge pull request #71 from pratikdas/heapdump
heap dump
2021-02-18 06:28:58 +11:00
Pratik Das
8e299cf819 Merge branch 'heapdump' of https://github.com/pratikdas/code-examples into heapdump 2021-02-17 15:12:13 +05:30
Pratik Das
14536868c5 removed target 2021-02-17 15:11:11 +05:30
Pratik Das
bbca460ed2 Merge branch 'master' into heapdump 2021-02-17 15:05:07 +05:30
Pratik Das
cd2e56a959 removed target 2021-02-17 14:59:12 +05:30
Pratik Das
143a5b53d0 removed target 2021-02-17 13:54:36 +05:30
Pratik Das
fec088b7db folder moved 2021-02-17 13:52:29 +05:30
Pratik Das
d68609b407 code added 2021-02-12 23:56:24 +05:30
Pratik Das
8b1ae3f3ed code added 2021-02-12 20:50:02 +05:30
Tom Hombergs
0ccd671636 fixing testcontainers issue 2021-02-09 07:31:03 +11:00
Tom Hombergs
1dac3ad175 trying to fix "Docker image not found" error 2021-02-09 07:18:04 +11:00
Tom Hombergs
91e38a8361 trying to fix "Docker image not found" error 2021-02-09 07:07:43 +11:00
Tom Hombergs
071651aa67 Merge pull request #70 from jgoerner/aws/s3
Aws/s3
2021-02-09 06:33:33 +11:00
jgoerner
a6c5ab4cd7 Add module to build script 2021-02-07 00:49:30 +01:00
jgoerner
c28b2d4a73 Update Readme 2021-02-03 21:13:32 +01:00
jgoerner
8bca7692e2 Finish initial version 2021-02-03 21:11:58 +01:00
Tom Hombergs
d1b5b19dd6 Merge pull request #69 from ortelagode/cookies
Cookies
2021-01-26 08:21:43 +11:00
Tom Hombergs
d5ff8dae58 add cookie module to CI build 2021-01-26 08:10:22 +11:00
Ortela Gode
4bb5bb8af9 updated name of cookie 2021-01-23 22:52:00 +01:00
Ortela Gode
e03595d5bd updated readme 2021-01-18 22:08:50 +01:00
Tom Hombergs
b5cfe4ad2a Update README.md 2021-01-18 08:19:21 +11:00
Tom Hombergs
4a64888977 Merge pull request #68 from pratikdas/graphql
graphql code
2021-01-18 08:08:21 +11:00
Ortela Gode
44d082c163 added example project for cookies 2021-01-17 20:01:49 +01:00
Pratik Das
8b3fc4cf5c graphql code 2021-01-15 18:18:14 +05:30
Pratik Das
5bd780f9c8 Merge branch 'master' into graphql 2021-01-15 18:06:39 +05:30
Pratik Das
eba824b908 graphql code 2021-01-15 17:55:28 +05:30
dependabot[bot]
8de5f6d41c Bump axios from 0.18.0 to 0.21.1 in /pact/pact-react-consumer
Bumps [axios](https://github.com/axios/axios) from 0.18.0 to 0.21.1.
- [Release notes](https://github.com/axios/axios/releases)
- [Changelog](https://github.com/axios/axios/blob/v0.21.1/CHANGELOG.md)
- [Commits](https://github.com/axios/axios/compare/v0.18.0...v0.21.1)

Signed-off-by: dependabot[bot] <support@github.com>
2021-01-05 03:23:41 +00:00
Tom Hombergs
381be70991 Merge pull request #66 from murtuza-ranapur/spring-boot-exception-handling
Adds Code example for Spring Boot exception Handling tutorial
2020-12-30 07:48:53 +11:00
murtuza-ranapur
87a6cac6b3 Adds logs 2020-12-28 23:13:28 +05:30
murtuza-ranapur
fef6c48fe1 Uses proper build command 2020-12-27 16:03:47 +05:30
murtuza-ranapur
3f59bd2ea4 Adds Code example for Spring Boot exception Handling tutorial 2020-12-27 15:54:15 +05:30
Tom Hombergs
e2d6cc3acb Merge pull request #64 from saajn/circuitbreaker
Circuitbreaker
2020-12-21 06:49:54 +11:00
Tom Hombergs
fef53fa72a fix link 2020-12-18 06:38:48 +11:00
Tom Hombergs
6b2ad23059 Merge pull request #63 from pratikdas/spring-boot-elasticsearch
Spring boot elasticsearch
2020-12-18 06:38:10 +11:00
Pratik Das
368a059cfe updated read.me 2020-12-17 19:58:06 +05:30
Pratik Das
67b4cbe08f modified 2020-12-17 14:23:15 +05:30
Saajan
0514f9f517 Merge branch 'master' of https://github.com/thombergs/code-examples into circuitbreaker 2020-12-14 12:30:10 +05:30
Saajan
76bcc6c016 Added circuitbreaker module to build-all.sh 2020-12-14 12:11:28 +05:30
Saajan
fd14c4c13e Added readme file 2020-12-14 12:07:34 +05:30
Saajan
39dbdc129f Added maven wrapper 2020-12-14 12:03:57 +05:30
Saajan
dbaa38a5fe Initial check in 2020-12-14 12:00:48 +05:30
Pratik Das
8f6e222ef2 Merge branch 'spring-boot-elasticsearch' of https://github.com/pratikdas/code-examples into spring-boot-elasticsearch 2020-12-13 18:04:37 +05:30
Pratik Das
88c5ff3dc7 added es code 2020-12-13 17:58:28 +05:30
Pratik Das
4cf2cbc10c Merge branch 'master' into spring-boot-elasticsearch 2020-12-13 17:40:20 +05:30
Pratik Das
e4e3d8a55b added es code 2020-12-13 17:32:44 +05:30
Pratik Das
d41fa4a006 added es code 2020-12-13 17:13:58 +05:30
Pratik Das
48cdce6e65 added es code 2020-12-13 17:12:14 +05:30
Tom Hombergs
2d8c099993 add gradle wrapper 2020-12-08 06:21:39 +11:00
Tom Hombergs
1c92604f3b add module about mocking Spring Boot modules 2020-12-08 06:18:06 +11:00
Tom Hombergs
6a63059b8c Merge pull request #62 from murtuza-ranapur/specification
Adds Intro to specification example code
2020-11-16 11:24:39 +11:00
murtuza-ranapur
1de287bcdb Adds review changes 2020-11-14 18:40:42 +05:30
murtuza-ranapur
f044fcc228 Adds review changes 2020-11-14 16:55:38 +05:30
murtuza-ranapur
ee1712c245 Fix failing test cases 2020-11-09 23:22:09 +05:30
murtuza-ranapur
8f03b89816 Adds specification to build all file 2020-11-09 23:17:34 +05:30
murtuza-ranapur
f751203867 * Adds Intro to specification example code 2020-11-09 23:15:03 +05:30
Tom Hombergs
4c4469b43b Merge pull request #52 from murtuza-ranapur/hibernate-search
Hibernate search
2020-10-07 09:00:12 +11:00
murtuza-ranapur
0e40dbfee3 * Removes default test case 2020-10-03 13:18:48 +05:30
Murtuza Ranapur
d47db42925 Merge branch 'master' into hibernate-search 2020-10-03 11:47:44 +05:30
murtuza-ranapur
04dcc8097a Merge remote-tracking branch 'origin/hibernate-search' into hibernate-search 2020-10-03 11:44:48 +05:30
murtuza-ranapur
ec52966e5f * Adds hibernate-search to build-all.sh 2020-10-03 11:44:34 +05:30
Tom Hombergs
b982958196 Merge pull request #56 from susetech/code-examples-suse-branch
Processing Files using Java 8 Streams
2020-09-27 07:52:15 +10:00
Tom Hombergs
974872ed8e Merge branch 'master' into code-examples-suse-branch 2020-09-27 07:41:54 +10:00
Tom Hombergs
0edc9e3e8e fix build and add to build-all.sh 2020-09-27 07:39:25 +10:00
Tom Hombergs
7d4dd46e2c Merge remote-tracking branch 'susetech/code-examples-suse-branch' into code-examples-suse-branch 2020-09-27 07:25:08 +10:00
Tom Hombergs
5169b74c86 Update README.md 2020-09-24 06:56:17 +10:00
Tom Hombergs
b5dc195722 Merge pull request #57 from itsLucario/component-scan
Component scan code example
2020-09-24 06:18:41 +10:00
Nandan Bn
47a1d0c4b7 component-scan readme & build module added 2020-09-23 15:55:31 +05:30
Nandan Bn
cacef37325 Merge remote-tracking branch 'upstream/master' 2020-09-23 15:37:07 +05:30
Nandan Bn
ab9aa60613 Spring Component Scanning 2020-09-23 15:36:39 +05:30
Tom Hombergs
782b64a32f Merge pull request #53 from pratikdas/spring-booot-health-check
added code for health check
2020-09-22 07:01:33 +10:00
Pratik Das
2f948c0616 Merge branch 'spring-booot-health-check' of https://github.com/pratikdas/code-examples into spring-booot-health-check 2020-09-21 21:06:59 +04:00
Pratik Das
2e3d9a03b6 modified few classes 2020-09-21 21:05:38 +04:00
susetech
0e48de379f Read me changes 2020-09-20 19:20:57 +05:30
susetech
08d2592311 Maven wraper 2020-09-20 09:07:28 +05:30
Tom Hombergs
313889e494 Merge branch 'master' into hibernate-search 2020-09-20 07:33:46 +10:00
Tom Hombergs
6058641b80 Merge branch 'master' into spring-booot-health-check 2020-09-20 07:33:13 +10:00
Tom Hombergs
ba8ba61586 Merge branch 'master' into code-examples-suse-branch 2020-09-20 07:32:39 +10:00
Tom Hombergs
ec595e8bae disable tests that make problems on Github Actions 2020-09-20 07:11:41 +10:00
Tom Hombergs
743bf01b0d attempt to make the @Disabled annotation work 2020-09-20 06:59:29 +10:00
Tom Hombergs
ca9cc4ad65 Merge remote-tracking branch 'origin/master' 2020-09-20 06:48:51 +10:00
susetech
b2ee3aafa3 Change in read me file 2020-09-19 22:05:47 +05:30
susetech
f137ea52db Read Me file 2020-09-19 21:48:34 +05:30
susetech
13888f806e Full example code and resources 2020-09-19 16:39:55 +05:30
Pratik Das
778a3d1d6f added mvn wrapper 2020-09-19 10:08:54 +04:00
Pratik Das
8b277387a1 added code for health check 2020-09-19 09:48:42 +04:00
Pratik Das
029a5f03fb added code for health check 2020-09-19 09:44:17 +04:00
Tom Hombergs
2958843c5a disable tests that don't work in Github Actions 2020-09-17 20:54:15 +10:00
Tom Hombergs
daa95bdf02 Merge pull request #51 from saajn/bulkhead
Bulkhead article examples
2020-09-17 07:44:25 +10:00
murtuza-ranapur
316fffdd7c * Adds README.md 2020-09-16 22:35:33 +05:30
Saajan
c65e2b2165 Added bulkhead module 2020-09-16 21:03:20 +05:30
Saajan
44b4842849 Added readme file 2020-09-16 20:59:13 +05:30
Saajan
947c68f0a8 Initial commit 2020-09-16 20:32:08 +05:30
murtuza-ranapur
927c51a2bb * Adds README.md 2020-09-16 18:39:24 +05:30
murtuza-ranapur
07265e54ed * Adds hibernate search example application 2020-09-16 18:26:35 +05:30
susetech
00b00e6e77 Initial commit of processing files with java streams code samples 2020-09-12 12:16:11 +05:30
Tom Hombergs
1eabfebeb0 Merge pull request #50 from pratikdas/spring-boot-docker
added docker related files
2020-09-05 07:49:29 +10:00
Pratik Das
b9b6ee02c5 added docker files wrapper 2020-08-30 13:14:33 +04:00
Pratik Das
64f680bd70 added docker files 2020-08-30 12:23:08 +04:00
Pratik Das
e833835beb added docker files 2020-08-30 12:17:43 +04:00
Tom Hombergs
c358d28ca6 Merge pull request #48 from pratikdas/springboot-logger-dtls
added code for spring boot logging
2020-08-24 06:22:19 +10:00
Pratik Das
ba285f6ee8 added wrapper 2020-08-23 14:57:29 +04:00
Pratik Das
72d7a158b2 renamed module 2020-08-23 14:46:47 +04:00
Tom Hombergs
c8f550a222 Merge pull request #45 from saajn/timelimiter
Code examples for TimeLimiter
2020-08-18 06:58:59 +10:00
Pratik Das
7324634620 updated readme 2020-08-16 17:58:38 +04:00
Pratik Das
b1d595be27 added code for spring boot logging 2020-08-16 16:34:58 +04:00
Tom Hombergs
8e9def0e7e Create README.md 2020-08-15 16:11:56 +10:00
Tom Hombergs
4141cefdec Create README.md 2020-08-15 16:09:42 +10:00
Tom Hombergs
ffcdc70902 Create README.md 2020-08-15 16:09:09 +10:00
Tom Hombergs
445173072d Create README.md 2020-08-15 16:07:47 +10:00
Tom Hombergs
bb7b3c1a95 Create README.md 2020-08-15 16:07:07 +10:00
Tom Hombergs
3d255abdaf Create README.md 2020-08-15 16:06:33 +10:00
Tom Hombergs
308663a9fd Create README.md 2020-08-15 16:06:02 +10:00
Tom Hombergs
b793060c05 Create README.md 2020-08-15 16:05:37 +10:00
Tom Hombergs
008636f6fa Create README.md 2020-08-15 16:05:00 +10:00
Tom Hombergs
467aaa1e07 Create README.md 2020-08-15 16:03:46 +10:00
Tom Hombergs
8e79ba1efa Create README.md 2020-08-15 16:02:37 +10:00
Tom Hombergs
d222085520 Create README.md 2020-08-15 16:01:48 +10:00
Tom Hombergs
3d128c346e Create README.md 2020-08-15 16:01:11 +10:00
Tom Hombergs
c4e387b408 Create README.md 2020-08-15 15:53:55 +10:00
Tom Hombergs
788e477803 Create README.md 2020-08-15 15:53:20 +10:00
Tom Hombergs
5983abbf68 Create README.md 2020-08-15 15:53:08 +10:00
Tom Hombergs
2b096d0470 Create README.md 2020-08-15 15:52:16 +10:00
Tom Hombergs
712bef33d8 Update README.md 2020-08-15 15:38:28 +10:00
Tom Hombergs
7148869bac Update README.md 2020-08-15 15:37:09 +10:00
Tom Hombergs
68ef61997d Create README.md 2020-08-15 15:36:53 +10:00
Tom Hombergs
12ba1f793e Create README.md 2020-08-15 15:32:54 +10:00
Tom Hombergs
e42b7e8c4c Create README.md 2020-08-15 15:31:20 +10:00
Tom Hombergs
a8e491c22a don't run actions on changes to markdown files 2020-08-15 15:29:13 +10:00
Tom Hombergs
570b5f4abf Merge pull request #47 from thombergs/devtools
Devtools
2020-08-12 06:57:04 +10:00
Tom Hombergs
7bf0c76554 add Gradle wrapper 2020-08-12 06:50:20 +10:00
Tom Hombergs
bf9ea8e515 add README 2020-08-12 06:49:36 +10:00
Tom Hombergs
39260d1b60 add restart excludes 2020-08-12 06:46:19 +10:00
Tom Hombergs
1c7ea0ab08 Merge pull request #46 from yavuztas/38-the-lifecycle-f-spring-beans
38 the lifecycle f spring beans
2020-08-11 06:49:17 +10:00
Tom Hombergs
7416ec273a dev tools demo 2020-08-10 21:07:55 +10:00
Yavuz Tas
7bebf8ccfd Merge branch '38-the-lifecycle-f-spring-beans' of https://github.com/yavuztas/code-examples into 38-the-lifecycle-f-spring-beans 2020-08-09 15:57:52 +02:00
Yavuz Tas
29f039ff97 add sample test for Quartz integration 2020-08-09 15:57:28 +02:00
Saajan
c45f41d171 Removed unused test class 2020-08-08 21:26:09 +05:30
Saajan
a83e8c34c6 Back merged from offical repo 2020-08-08 21:23:03 +05:30
Saajan
1e5e5e2e91 Removed commented lines in ratelimiter pom 2020-08-08 21:21:02 +05:30
Saajan
31025040dc Added timelimiter module to build-all 2020-08-08 21:19:48 +05:30
Saajan
ccc5fdb306 Initial check in 2020-08-08 21:14:25 +05:30
Tom Hombergs
8bbf1388b1 Create README.md 2020-08-08 17:56:54 +10:00
Tom Hombergs
33649d5d8d Update README.md 2020-08-08 17:55:02 +10:00
Tom Hombergs
53bb36722c Create README.md 2020-08-08 17:54:35 +10:00
Tom Hombergs
a38f213cd6 move ISP code into it's own module 2020-08-08 17:51:59 +10:00
Tom Hombergs
895b51f518 Update and rename Readme.md to README.md 2020-08-08 17:46:39 +10:00
Tom Hombergs
47f93fa65b Update and rename Readme.md to README.md 2020-08-08 17:45:49 +10:00
Tom Hombergs
3b2bdca1f5 Create README.md 2020-08-08 17:44:09 +10:00
Tom Hombergs
bbb40924d9 Update README.md 2020-08-08 17:42:04 +10:00
Tom Hombergs
ac7df576e3 Create README.md 2020-08-08 17:39:37 +10:00
Tom Hombergs
cceeb999cd Update README.md 2020-08-08 17:38:32 +10:00
Tom Hombergs
ae3e8c6884 Update README.md 2020-08-08 17:38:07 +10:00
Tom Hombergs
409261f790 Update README.md 2020-08-08 17:37:42 +10:00
Tom Hombergs
1fe6e5102e Create README.md 2020-08-08 17:37:06 +10:00
Tom Hombergs
dbc126e49e re-enable testcontainers 2020-08-08 17:29:29 +10:00
Tom Hombergs
22193d8c28 fix YAML 2020-08-08 17:20:36 +10:00
Tom Hombergs
0e69088cb0 fix YAML 2020-08-08 17:17:49 +10:00
Tom Hombergs
8ea03ad675 upload build reports to analyze failure 2020-08-08 17:13:39 +10:00
Tom Hombergs
e9f891c9ea Merge pull request #44 from yavuztas/38-the-lifecycle-f-spring-beans
code examples for the article 38 - the lifecycle of spring beans
2020-08-08 11:43:24 +10:00
Tom Hombergs
d6122da3a1 Add README and add module to build 2020-08-08 11:19:52 +10:00
Yavuz Tas
b10a25e9fb remove duplicate directory 2020-08-04 01:42:09 +02:00
Yavuz Tas
49a8cf0df8 code examples for the article 38 the lifecycle of spring beans 2020-08-04 00:55:04 +02:00
Tom Hombergs
c657c7cbd2 Merge pull request #42 from saajn/ratelimit
Implementing Rate Limiting with Resilience4j
2020-07-31 07:33:58 +10:00
Tom Hombergs
998bf5f27f Merge pull request #43 from arkuksin/request-response
Request-response
2020-07-31 06:39:06 +10:00
Tom Hombergs
44ffd6541d Merge branch 'master' into ratelimit 2020-07-31 06:34:34 +10:00
Tom Hombergs
cee21dc541 add README 2020-07-31 06:31:17 +10:00
Tom Hombergs
1d30ae6575 Merge branch 'master' into request-response 2020-07-31 06:26:16 +10:00
Tom Hombergs
532c311ee1 run build on PRs 2020-07-31 06:20:56 +10:00
akuksin
414f7fe963 Add script for starting rabbitmq with docker. 2020-07-29 20:20:23 +02:00
akuksin
228767ec9b Make method package private in the mapper. 2020-07-29 19:15:28 +02:00
Saajan
aa2dfd8f7b Back merges from official 2020-07-29 16:00:13 +05:30
Saajan
761ee1ae56 Upgrades java version to 11 2020-07-29 15:55:27 +05:30
Saajan
b5b7477277 Adds ratelimiter module 2020-07-29 15:37:10 +05:30
Saajan
b254e97227 Adds article link to readme 2020-07-29 15:32:18 +05:30
Saajan
e754075e7a Initial check in 2020-07-29 15:22:51 +05:30
Saajan
a8414fd370 Initial check in & url fix in retry pom.xml 2020-07-29 15:17:38 +05:30
Saajan
cfcae5e2d6 Initial check in 2020-07-29 15:16:50 +05:30
akuksin
2145f1e823 Change gradle-wrapper version. 2020-07-29 07:45:09 +02:00
akuksin
b6606d3173 Add request-response projects to build-all.sh. 2020-07-29 00:49:46 +02:00
akuksin
f09271ae2c Merge branch 'master' into request-response
# Conflicts:
#	spring-boot/request-response/client/gradle/wrapper/gradle-wrapper.jar
#	spring-boot/request-response/client/gradle/wrapper/gradle-wrapper.properties
#	spring-boot/request-response/client/gradlew
#	spring-boot/request-response/client/gradlew.bat
#	spring-boot/request-response/server/gradle/wrapper/gradle-wrapper.jar
#	spring-boot/request-response/server/gradle/wrapper/gradle-wrapper.properties
#	spring-boot/request-response/server/gradlew
#	spring-boot/request-response/server/gradlew.bat
2020-07-29 00:47:28 +02:00
akuksin
dd264fe6f7 Add gradle wrapper. 2020-07-29 00:46:55 +02:00
akuksin
62933c822d Add gradle files. 2020-07-29 00:46:03 +02:00
akuksin
c4575df3a5 Add Tests. Refactoring. 2020-07-29 00:41:53 +02:00
Tom Hombergs
a36255a670 README 2020-07-26 21:01:19 +10:00
Tom Hombergs
c35f171d32 refactor to package the Vue components into the JAR instead of copying files around 2020-07-26 20:55:39 +10:00
Tom Hombergs
44fe1a4945 Update PR checklist and README 2020-07-26 09:43:22 +10:00
Tom Hombergs
68c676fc7f Add PR checklist and a 5th module 2020-07-26 09:41:11 +10:00
Tom Hombergs
a6dca60d73 remove testcontainers because it wasn't needed and caused "address already in used" errors 2020-07-26 09:23:01 +10:00
Tom Hombergs
635e9d8886 add missing gradle wrapper files 2020-07-26 09:04:54 +10:00
Tom Hombergs
1fa58e9379 add dummy AWS credentials 2020-07-26 08:12:25 +10:00
Tom Hombergs
3d7839ca99 add dummy AWS credentials 2020-07-26 08:02:32 +10:00
Tom Hombergs
72411d1c38 fix localstack issue 2020-07-26 07:56:19 +10:00
Tom Hombergs
9b38589de1 fix Jacoco build 2020-07-26 07:40:28 +10:00
Tom Hombergs
0d9b022cb9 upgrade to Gradle 6.5 2020-07-26 07:18:04 +10:00
Tom Hombergs
70857b2f22 update several dependencies for builds to work 2020-07-26 07:12:40 +10:00
akuksin
f2dd80ff03 Add Listener for Reply Consumer. 2020-07-25 12:27:23 +02:00
Tom Hombergs
7166218d64 fix issue with npmInstall 2020-07-25 20:23:42 +10:00
Tom Hombergs
b61db5648d split up in multiple (parallel) build modules 2020-07-25 20:19:04 +10:00
Tom Hombergs
165a2a9ae5 split up in multiple (parallel) build modules 2020-07-25 20:14:53 +10:00
Tom Hombergs
f5357af028 split up in multiple (parallel) build modules 2020-07-25 20:13:18 +10:00
Tom Hombergs
eefdfd2655 upgrade to Gradle 6.5 2020-07-25 19:41:40 +10:00
Tom Hombergs
bae565cc37 Merge pull request #40 from pratikdas/aws-localstack
added localstack code
2020-07-22 07:13:43 +10:00
Tom Hombergs
e1c0e0eeb7 move localstack build to the end to see if all other modules are building 2020-07-22 07:13:24 +10:00
Tom Hombergs
1ee2379ce9 add AWS env vars 2020-07-22 07:09:47 +10:00
Tom Hombergs
ecda1078fc Merge branch 'master' into aws-localstack 2020-07-22 06:57:30 +10:00
Tom Hombergs
f5aae13fed fixes 2020-07-22 06:56:07 +10:00
Tom Hombergs
0fd1480028 update build to Java 13 2020-07-22 06:30:14 +10:00
akuksin
e4e5c001ba Remove unnecessary dependency. 2020-07-21 20:52:45 +02:00
akuksin
8fb0da2c72 Remove unnecessary dependency. 2020-07-21 20:45:26 +02:00
akuksin
9cfd8ed344 Add integration test for RPC with Spring Boot AMQP for the server. 2020-07-20 23:32:30 +02:00
Tom Hombergs
2b1d8e4682 Merge pull request #41 from thombergs/itsLucario/master
Its lucario/master
2020-07-21 07:31:21 +10:00
Tom Hombergs
339a0db992 Merge branch 'master' into itsLucario/master 2020-07-21 07:30:40 +10:00
Tom Hombergs
8efc1d139b removed test that needs access to Kafka 2020-07-21 07:28:04 +10:00
akuksin
94ea44f5fe Add integration test for RPC with Spring Boot AMQP. 2020-07-20 20:36:18 +02:00
akuksin
3c12cfb17b Add RPC with AMQP (Client and Server). 2020-07-20 19:51:58 +02:00
Nandan Bn
ef9ad9a6fd CInj and some fixes 2020-07-20 15:12:32 +05:30
Pratik Das
4a98c430d4 rearranged folders 2020-07-20 09:31:30 +04:00
Tom Hombergs
432f4ea3bc Merge pull request #39 from saajn/retry
Example code for resilience4j retry
2020-07-16 20:24:19 +10:00
Tom Hombergs
9d875fd412 add retry module to build 2020-07-16 20:23:49 +10:00
Pratik Das
a2692da265 added localstack code 2020-07-15 23:04:06 +04:00
Saajan
251acca5d5 Reorganized the directories 2020-07-15 16:14:18 +05:30
Saajan
e4c78bc9fa Removes remoteservice project 2020-07-15 15:27:06 +05:30
Saajan
75fead124d Clean up and exception related examples changes 2020-07-15 15:24:07 +05:30
Nandan Bn
155521ea11 Added example for ProducerListener & fixes 2020-07-14 20:31:15 +05:30
Saajan
81355cd289 Adds Readme file 2020-07-14 17:54:56 +05:30
Tom Hombergs
88fd0640ad Merge remote-tracking branch 'origin/master' 2020-07-12 20:21:49 +10:00
Tom Hombergs
9904d7206e AWS ECS Deployment example 2020-07-12 20:21:43 +10:00
Saajan
e552dd3506 Initial commit 2020-07-09 17:04:04 +05:30
Nandan Bn
568fd5d7aa Spring Boot Kafka Example 2020-07-06 20:03:57 +05:30
Tom Hombergs
9a2440a58a Merge pull request #37 from saajn/master
Makes the superclasses abstract
2020-07-03 06:13:49 +10:00
Saajan
d4458e88ad Makes the superclasses abstract 2020-07-02 11:25:36 +05:30
Tom Hombergs
079635b3ad Merge pull request #36 from saajn/master
LSP explained
2020-07-02 07:00:56 +10:00
Tom Hombergs
035b9f7020 add LSP module to builds 2020-07-02 06:58:55 +10:00
Tom Hombergs
457daf5fc1 Merge pull request #35 from arkuksin/hazelcast
Implement StreamSerializer for Car object.
2020-07-01 06:47:10 +10:00
Saajan
a64c2521de Initial commit 2020-06-29 15:30:54 +05:30
akuksin
791a603f34 Implement StreamSerializer for Car object. 2020-06-27 23:35:56 +02:00
Tom Hombergs
8729639907 upgrade spring boot gradle plugin to work with Java 13 2020-06-28 07:20:46 +10:00
Tom Hombergs
ec9992c0ba fix build issue in "modular" module 2020-06-27 08:29:50 +10:00
Tom Hombergs
4f5a370999 fix typo in package name 2020-06-27 06:33:50 +10:00
Tom Hombergs
a856ef260b upgrade to Gradle 6.5 2020-06-27 06:31:28 +10:00
Tom Hombergs
7613384396 update to Gradle 6.5 2020-06-27 06:30:26 +10:00
Tom Hombergs
fd484488ca Merge pull request #34 from arkuksin/cache
Implement DataSerializable for the Car
2020-06-27 06:26:46 +10:00
akuksin
b2a9eea9e2 implement DataSerializable for the Car 2020-06-25 22:06:54 +02:00
Tom Hombergs
58be70d34a Merge pull request #33 from arkuksin/cache
Cache
2020-06-24 07:14:37 +10:00
akuksin
97c639f902 add cache project to build script. 2020-06-22 21:14:32 +02:00
akuksin
a14c65566a add custom key for caching 2020-06-22 21:13:14 +02:00
akuksin
6b66a6e980 use ClientConfig to configure client-server Hazelcast cache 2020-06-22 00:04:04 +02:00
thombergs
a18d01bd4b fix module to work with Gradle 6.5 2020-06-21 23:11:47 +10:00
thombergs
f1b64604c0 Upgrade more modules to Gradle 6.5 2020-06-21 22:36:13 +10:00
Tom Hombergs
7c3be096f1 Update to Gradle 6.5 2020-06-21 21:23:42 +10:00
Tom Hombergs
d2ce081264 Update CI badge 2020-06-21 21:16:56 +10:00
Tom Hombergs
3c6895b295 Update all modules to Gradle 6.5 to support Java 13 2020-06-21 21:14:20 +10:00
Tom Hombergs
2395a605b4 Add Github Actions 2020-06-21 20:42:45 +10:00
Tom Hombergs
6c86c730c5 Fix wrong order of arguments in assertThat() 2020-06-21 18:55:31 +10:00
Tom Hombergs
0815698aff Add link to article. 2020-06-21 18:15:18 +10:00
Tom Hombergs
4e0ede6fb8 Merge remote-tracking branch 'origin/master' 2020-06-21 18:14:15 +10:00
Tom Hombergs
4de6c17ae1 Add missing diagram. 2020-06-21 18:14:08 +10:00
akuksin
fa53509c36 clean up 2020-06-21 00:36:48 +02:00
akuksin
2273d59166 add hazelcast with client-server topology 2020-06-18 23:11:44 +02:00
akuksin
2a82919aa1 Merge branch 'master' into cache
# Conflicts:
#	spring-boot/hazelcast/hazelcast-client-server/src/test/java/io/reflectoring/cache/cleint/AbstractIntegrationTest.java
2020-06-18 22:02:15 +02:00
akuksin
60f6c7e585 add crud functionality with a in-memory database 2020-06-15 22:43:25 +02:00
Tom Hombergs
31c09ae8dc Merge pull request #32 from arkuksin/hazelcast
Hazelcast
2020-06-14 07:45:03 +10:00
akuksin
07b2572541 use nearCache 2020-06-13 01:11:13 +02:00
akuksin
7021c7ddea use hazelcast version 4.0.1 2020-06-13 01:04:24 +02:00
Tom Hombergs
8c9f67f2f8 Use JDK 13 in Travis build 2020-06-09 07:13:56 +10:00
Tom Hombergs
96a58ce851 Add npmInstall to build-all.sh 2020-06-09 06:56:04 +10:00
Tom Hombergs
5e0f15e4cc Thymeleaf + Vue application 2020-06-08 21:51:46 +10:00
Tom Hombergs
b8c0923f23 rename module to "spring-boot-springdoc" 2020-06-05 07:18:14 +10:00
Tom Hombergs
2e3cdcec99 Merge pull request #28 from Petros0/reflect-92
reflect-92 (Code-First API Documentation with Swagger)
2020-06-05 07:11:24 +10:00
Tom Hombergs
0deff1fb44 Merge pull request #31 from arkuksin/hazelcast
Hazelcast
2020-06-03 06:56:47 +10:00
akuksin
34c76bb565 use putIfAbsent and not put in Hazelcast client 2020-05-31 22:42:50 +02:00
akuksin
92b3faa23c rename HazelcastNode to CacheClient 2020-05-31 22:41:35 +02:00
akuksin
430588dbdc typo 2020-05-28 23:10:49 +02:00
akuksin
786b98964c Add hazelcast project to build. 2020-05-28 22:24:38 +02:00
akuksin
fad637580c Use typed Map. 2020-05-28 22:22:49 +02:00
akuksin
e7f12e4b92 Add eviction configuration for the Map. 2020-05-26 23:02:41 +02:00
akuksin
de375d2c89 Merge branch 'hazelcast-embedded' 2020-05-26 22:49:23 +02:00
akuksin
fe79d77b62 make Car serializable. 2020-05-26 22:44:34 +02:00
Tom Hombergs
7cb1d952b8 Merge pull request #30 from thombergs/18-validate-spring-boot-configuration-parameters-at-startup
18 validate spring boot configuration parameters at startup
2020-05-27 06:36:15 +10:00
akuksin
df07d9c308 init project for Spring Boot with Hazelcast client 2020-05-26 22:35:02 +02:00
Tom Hombergs
97bf254d85 update to Java 13, fixing build 2020-05-27 06:33:15 +10:00
Yavuz Tas
381fe85e39 add a sample custom validator for AppProperties and add tests 2020-05-26 08:09:11 +02:00
Yavuz Tas
a418f21ff1 add third-party component properties example and update the tests 2020-05-26 05:50:40 +02:00
Tom Hombergs
f723e5f1f4 Merge pull request #29 from arkuksin/master
rename package 'de.kuksin' to 'io.refectoring'
2020-05-26 08:17:21 +10:00
akuksin
8080fc083e init project for Spring Boot with embedded Hazelcast cache. 2020-05-25 22:40:54 +02:00
akuksin
e1f6de8bd3 rename package 'de.kuksin' to 'io.refectoring' 2020-05-25 22:14:22 +02:00
Petros Stergioulas
c36bedd679 Remove actuator 2020-05-25 19:01:49 +02:00
Yavuz Tas
735d80d72f Code samples for Validate Spring Boot Configuration Parameters at Startup 2020-05-22 19:45:26 +02:00
Petros Stergioulas
eff3c3c935 Add security and actuator 2020-05-16 19:49:07 +02:00
Petros Stergioulas
94f88c4489 Add security and actuator 2020-05-16 19:46:43 +02:00
Tom Hombergs
3eb97d81ec CloudFormation stacks for creating a Postgres instance, deploying a Spring Boot app and connecting the app to the database. 2020-05-11 17:07:35 +10:00
Tom Hombergs
27e1428488 update readme 2020-05-09 22:00:20 +10:00
Tom Hombergs
7b63198a08 example Docker image requiring a database connection 2020-05-09 08:38:41 +10:00
Tom Hombergs
45c947ddc1 Merge pull request #25 from arkuksin/testcontainers
Testcontainers
2020-05-07 06:47:06 +10:00
akuksin
e41458b7cd Merge branch 'master' into testcontainers 2020-05-05 20:38:44 +02:00
akuksin
03ab12c64b remove @NotNull annotation 2020-05-05 17:37:41 +02:00
akuksin
f183c92661 refactoring 2020-05-05 17:14:24 +02:00
Tom Hombergs
109dacd121 Merge pull request #24 from arkuksin/testcontainers
Testcontainers
2020-05-03 07:12:57 +10:00
Tom Hombergs
0bff861d25 Add CloudFormation templates 2020-05-02 06:39:33 +10:00
akuksin
51be8954a9 Merge branch 'master' into testcontainers 2020-04-29 20:09:38 +02:00
akuksin
4bd0201900 Merge remote-tracking branch 'upstream/master'
# Conflicts:
#	build-all.sh
2020-04-29 20:08:59 +02:00
Petros Stergioulas
bb7ac442b1 Init 2020-04-29 20:07:36 +02:00
akuksin
074b118bff add comment 2020-04-25 20:17:16 +02:00
akuksin
1a4c9421dc clean up test 2020-04-22 23:56:35 +02:00
akuksin
6168a9a47a delete unnecessary code 2020-04-22 23:11:20 +02:00
akuksin
b6cd9b8138 add testcontainers project to build-all.sh 2020-04-22 22:47:26 +02:00
prabhakar349
cc153bfd06 feat(liquibase)[]: add liquibase code example 2020-04-22 22:42:51 +02:00
thombergs
cf3a36e108 remove unnecessary package check 2020-04-22 22:42:47 +02:00
thombergs
2e6e26193f polishing 2020-04-22 22:42:47 +02:00
Nandan Bn
ae8ec346fd Package visibility changes 2020-04-22 22:42:47 +02:00
Nandan Bn
caf408a550 Fixes and added examples for transactional... 2020-04-22 22:42:47 +02:00
Nandan Bn
4543443a82 Reflect-105 Code example 2020-04-22 22:42:47 +02:00
thombergs
ae813adb18 fixed build 2020-04-22 22:42:47 +02:00
thombergs
6a27f35b2a updated with valueOf() 2020-04-22 22:42:38 +02:00
thombergs
1f9fbc2543 changed class name 2020-04-22 22:42:38 +02:00
thombergs
52f8dfc91c reduce log output in Travis Build 2020-04-22 22:42:35 +02:00
Petros Stergioulas
a5305e266f Implement UserApiDelegate, instead of the UserApi 2020-04-22 22:42:28 +02:00
Petros Stergioulas
507ff901b4 Rename module to spring-boot-openapi, also add maven wrapper in root 2020-04-22 22:42:28 +02:00
Petros Stergioulas
8b5e2ce3a4 Reflect-91 init 2020-04-22 22:42:28 +02:00
thombergs
ebd2362c1c billingmodule -> billing 2020-04-22 22:42:28 +02:00
thombergs
72f40744dd billingmodule -> billing 2020-04-22 22:42:28 +02:00
thombergs
43f9e32282 added missing Gradle files 2020-04-22 22:42:27 +02:00
thombergs
f85a0f36ae example for clean architecture boundaries with Spring Boot 2020-04-22 22:42:27 +02:00
thombergs
1f2b333a8a listContributors -> contributors 2020-04-22 22:42:25 +02:00
akuksin
4f056283b3 replace @Autowired by @Bean annotation for the authentication provider 2020-04-22 22:42:25 +02:00
akuksin
054d177ef2 remove custom code for password migration, use the feature of DelegatingPasswordEncoder instead 2020-04-22 22:42:25 +02:00
akuksin
84f441dbeb rename JdbcUserDetailPasswordService to DatabaseUserDetailPasswordService 2020-04-22 22:42:25 +02:00
akuksin
b3be06ea00 remove @Transactional annotation from RegistrationResource 2020-04-22 22:42:24 +02:00
akuksin
1fa7f545fd rename UserResources to RegistrationResource 2020-04-22 22:42:24 +02:00
akuksin
32f3e4cefa rename daoAuthenticationProvider to provider 2020-04-22 22:42:24 +02:00
akuksin
5109d98167 rename JdbcUserDetailsService to DatabaseUserDetailsService 2020-04-22 22:42:24 +02:00
akuksin
dc12f67ae4 make classes package private, apply google-java-formatter 2020-04-22 22:42:24 +02:00
akuksin
8c34f22b7e remove unnecessary comment 2020-04-22 22:42:24 +02:00
akuksin
ffa9ac6d5e simplify the configuration 2020-04-22 22:42:24 +02:00
akuksin
0b9e63571e reformat code 2020-04-22 22:42:24 +02:00
akuksin
3b69be714e add calculation of bcryt strength with Divide-and-conquer algorithm 2020-04-22 22:42:24 +02:00
akuksin
2ae9c0b2ae add simple examples for password encoders 2020-04-22 22:42:24 +02:00
akuksin
ef9fe2c506 add project spring-boot/password-encoding 2020-04-22 22:42:24 +02:00
thombergs
9653304df2 Repository -> GitRepository 2020-04-22 22:42:24 +02:00
thombergs
b7dc19cb8d argumentresolver example 2020-04-22 22:42:24 +02:00
thombergs
16bdac5240 MethodArgumentResolver example 2020-04-22 22:42:20 +02:00
thombergs
53a7cd866f example of converters in Spring Data JDBC 2020-04-22 22:42:20 +02:00
Petromir Dzhunev
78fd7fb89f REFLECT-2 Add missing bits
Add undo migration, add Jenkins files, add Java-base migration
2020-04-22 22:41:47 +02:00
Petromir Dzhunev
94ebb0bde7 REFLECT-2 Remove redundant parameters to Gradle plugin 2020-04-22 22:41:47 +02:00
Petromir Dzhunev
681d34b775 REFLECT-2 Integrating H2 with Flyway 2020-04-22 22:41:47 +02:00
Petromir Dzhunev
d8ca7d3f04 Initial set-up of Flyway data migration project 2020-04-22 22:41:47 +02:00
thombergs
bf68901255 changes after review 2020-04-22 22:41:47 +02:00
Mukul Sharma
ab949c2a0b Reflect-76 ISP explained added code examples 2020-04-22 22:41:47 +02:00
thombergs
90f7b1ad39 refactored and made the tests work 2020-04-22 22:41:47 +02:00
Vasudha Venkatesan
4b959cb797 Code example for field injection and other changes 2020-04-22 22:41:47 +02:00
Vasudha Venkatesan
670c4c845a Code example changes 2020-04-22 22:41:47 +02:00
Vasudha Venkatesan
531d05de64 Code format changes and Added maven wrapper 2020-04-22 22:41:47 +02:00
Vasudha Venkatesan
3a929134ba Constructor and setter based Dependency injection code example 2020-04-22 22:41:47 +02:00
akuksin
f1aa143b96 initial commit 2020-04-22 21:11:39 +02:00
Tom Hombergs
f05e8f75cd Merge pull request #23 from pdigumarthi/feat-liquibase-example
feat(liquibase)[]: add liquibase code example
2020-04-14 08:33:29 +10:00
prabhakar349
190f2511af feat(liquibase)[]: add liquibase code example 2020-04-12 18:24:09 -04:00
thombergs
4ecc79977a remove unnecessary package check 2020-04-09 06:37:44 +10:00
Tom Hombergs
7e4b6d4cac Merge pull request #17 from Lucaarioo/master
Reflect-105 Code example
2020-03-31 06:10:11 +11:00
thombergs
e023c7c42f polishing 2020-03-31 06:06:50 +11:00
Tom Hombergs
a857ad5455 Merge pull request #18 from vasudhavenkatesan/master
REFLECT -104 : Constructor and setter based Dependency injection code example
2020-03-29 06:46:03 +11:00
thombergs
51460691bb fixed build 2020-03-28 06:34:57 +11:00
thombergs
01b0ef3eb8 Merge branch 'master' into vasudha-master 2020-03-28 06:29:07 +11:00
thombergs
4f006376c1 updated with valueOf() 2020-03-25 06:55:19 +11:00
thombergs
01db1e9805 refactored and made the tests work 2020-03-25 06:06:04 +11:00
thombergs
a989129816 changed class name 2020-03-14 08:58:44 +11:00
thombergs
4ceee9a453 reduce log output in Travis Build 2020-03-12 06:49:07 +11:00
Tom Hombergs
c90578311b Merge pull request #21 from thombergs/openapi
Openapi
2020-03-11 07:05:34 +11:00
thombergs
7cd125ee33 added to build-all.sh 2020-03-11 06:40:03 +11:00
thombergs
76e97842a2 Merge branch 'reflect-91' of https://github.com/Petros0/code-examples into openapi 2020-03-11 06:18:52 +11:00
thombergs
92aef0228e billingmodule -> billing 2020-03-11 05:45:01 +11:00
Vasudha Venkatesan
ca32144e80 Code example for field injection and other changes 2020-03-10 10:55:35 +05:30
thombergs
e8ef69917a billingmodule -> billing 2020-03-10 07:05:08 +11:00
Petros Stergioulas
5da17c5a20 Implement UserApiDelegate, instead of the UserApi 2020-03-09 20:08:40 +01:00
thombergs
8a36085425 added missing Gradle files 2020-03-07 08:42:37 +11:00
thombergs
1916f5b2af example for clean architecture boundaries with Spring Boot 2020-03-07 08:26:15 +11:00
thombergs
c69957d1b8 listContributors -> contributors 2020-03-06 06:40:27 +11:00
thombergs
426d1e77c6 Merge remote-tracking branch 'origin/master' 2020-03-05 06:23:17 +11:00
thombergs
ec681b5abc Repository -> GitRepository 2020-03-05 06:23:01 +11:00
Tom Hombergs
57ff03707c Merge pull request #19 from arkuksin/spring-boot-password-emcoding
add project spring-boot/password-encoding
2020-03-04 05:50:59 +11:00
thombergs
761fdd4d7a Merge remote-tracking branch 'origin/master'
# Conflicts:
#	build-all.sh
2020-03-02 21:17:41 +11:00
thombergs
939e864a4a example of converters in Spring Data JDBC 2020-03-02 21:16:33 +11:00
akuksin
84c593016b replace @Autowired by @Bean annotation for the authentication provider 2020-03-01 11:41:50 +01:00
akuksin
e0a456724d remove custom code for password migration, use the feature of DelegatingPasswordEncoder instead 2020-03-01 10:48:52 +01:00
Tom Hombergs
c8a15d4d4d Merge pull request #20 from thombergs/argumentresolver
Argumentresolver
2020-03-01 09:37:07 +11:00
akuksin
0b9a101b08 rename JdbcUserDetailPasswordService to DatabaseUserDetailPasswordService 2020-02-28 19:32:50 +01:00
akuksin
1b9f2426a4 remove @Transactional annotation from RegistrationResource 2020-02-27 22:42:36 +01:00
akuksin
3ab8517320 rename UserResources to RegistrationResource 2020-02-27 22:40:11 +01:00
akuksin
77151d1752 rename daoAuthenticationProvider to provider 2020-02-27 22:36:06 +01:00
akuksin
b73731159f rename JdbcUserDetailsService to DatabaseUserDetailsService 2020-02-27 22:22:16 +01:00
akuksin
bfd004b73a make classes package private, apply google-java-formatter 2020-02-27 22:17:40 +01:00
Vasudha Venkatesan
1f4484f25f Code example changes 2020-02-26 14:43:33 +05:30
akuksin
ab5143cb2f remove unnecessary comment 2020-02-25 21:58:33 +01:00
akuksin
74f0e28e8e simplify the configuration 2020-02-25 20:12:30 +01:00
Nandan Bn
47baf5ea91 Package visibility changes 2020-02-25 01:08:13 +05:30
Vasudha Venkatesan
61ed2eaaa8 Code format changes and Added maven wrapper 2020-02-24 12:44:47 +05:30
akuksin
d55ee992f3 reformat code 2020-02-22 23:39:48 +01:00
akuksin
9a378b5763 add calculation of bcryt strength with Divide-and-conquer algorithm 2020-02-22 23:35:21 +01:00
Nandan Bn
c4ba025b17 Fixes and added examples for transactional... 2020-02-22 10:22:16 +05:30
akuksin
4ca9b30b94 add simple examples for password encoders 2020-02-20 22:10:17 +01:00
akuksin
0847972b5a add project spring-boot/password-encoding 2020-02-17 22:24:01 +01:00
Vasudha Venkatesan
1e9c30733d Constructor and setter based Dependency injection code example 2020-02-17 22:46:46 +05:30
Nandan Bn
90657e3a6b Reflect-105 Code example 2020-02-17 12:02:27 +05:30
Petros Stergioulas
26739aada2 Rename module to spring-boot-openapi, also add maven wrapper in root 2020-02-11 20:59:00 +01:00
Petros Stergioulas
dabc601384 Reflect-91 init 2020-02-09 22:25:26 +01:00
2738 changed files with 232315 additions and 1068 deletions

52
.github/workflows/ci.yml vendored Normal file
View File

@@ -0,0 +1,52 @@
name: CI
on:
push:
paths-ignore:
- '**/*.md'
pull_request:
paths-ignore:
- '**/*.md'
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
# The MODULE environment variable is evaluated in build-all.sh to run a subset
# of the builds. This way, multiple modules can be built in parallel.
module: [ "module1", "module2", "module3", "module4", "module5", "module6", "module7" ]
steps:
- name: "Checkout sources"
uses: actions/checkout@v1
- name: "Setup Java"
uses: actions/setup-java@v1
with:
java-version: 13
- name: "Build module ${{ matrix.module }}"
env:
MODULE: ${{ matrix.module }}
# We don't actually need AWS credentials in the tests, but LocalStack
# complains if they're not there, so we add dummies to the environment.
AWS_ACCESS_KEY_ID: dummy
AWS_SECRET_ACCESS_KEY: dummy
AWS_REGION: us-east-1
run: |
chmod 755 build-all.sh && ./build-all.sh $MODULE
- name: "Zip build reports"
if: failure()
run: zip -r reports.zip **/**/build/reports
- uses: actions/upload-artifact@v1
name: "Upload build reports"
if: failure()
with:
name: reports
path: reports.zip

2
.gitignore vendored
View File

@@ -1,3 +1,5 @@
**/.idea/
**/*.iml
**/.DS_Store
**/.terraform

View File

@@ -15,4 +15,4 @@ script:
language: java
jdk:
- oraclejdk11
- oraclejdk13

View File

@@ -1,21 +1,8 @@
# Example Code Repository
[![Travis CI Status](https://travis-ci.org/thombergs/code-examples.svg?branch=master)](https://travis-ci.org/thombergs/code-examples)
[![CI](https://github.com/thombergs/code-examples/workflows/CI/badge.svg)](https://github.com/thombergs/code-examples/actions?query=workflow%3ACI)
This repo contains example projects which show how to use different (not only) Java technologies.
The examples are usually accompanied by a blog post on [https://reflectoring.io](https://reflectoring.io).
See the READMEs in each subdirectory of this repo for more information on each module.
## Java Modules
All Java modules require **Java 11** to compile and run.
### Building with Gradle
Each module should be an independent build and can be built by calling `./gradlew clean build` in the module directory.
All modules are listed in [build-all.sh](build-all.sh) to run in the CI pipeline.
### Non-Java Modules
Some folders contain non-Java projects. For those, refer to the README within the module folder.
See the READMEs in each subdirectory of this repo for more information on each module.

View File

@@ -0,0 +1,14 @@
# AWS Hello World
A simple Spring Boot application you can use to test deployments to AWS (or any other cloud provider, for that matter).
This application is also available as a Docker image on Docker Hub: [https://hub.docker.com/r/reflectoring/aws-hello-world](https://hub.docker.com/r/reflectoring/aws-hello-world).
## Blog posts
Blog posts about this topic:
* [The AWS Journey Part 1: Deploying Your First Docker Image](https://reflectoring.io/aws-deploy-docker-image-via-web-console/)
* [The AWS Journey Part 2: Deploying a Docker Image with AWS CloudFormation](https://reflectoring.io/aws-cloudformation-deploy-docker-image/)
* [The AWS Journey Part 3: Connecting a Spring Boot Application to an RDS Instance with CloudFormation](https://reflectoring.io/aws-cloudformation-rds/)
* [The AWS Journey Part 4: Zero-Downtime Deployment with CloudFormation and ECS](https://reflectoring.io/aws-cloudformation-ecs-deployment/)

View File

@@ -1,5 +1,5 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-6.0.1-bin.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-6.5-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists

View File

@@ -8,7 +8,7 @@ public class HelloWorldController {
@GetMapping("/hello")
public String helloWorld(){
return "Hello AWS!";
return "Hello AWS (v4)!";
}
}

32
aws/aws-rds-hello-world/.gitignore vendored Normal file
View File

@@ -0,0 +1,32 @@
HELP.md
.gradle
build/
!gradle/wrapper/gradle-wrapper.jar
!**/src/main/**
!**/src/test/**
### STS ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
out/
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
### VS Code ###
.vscode/

View File

@@ -0,0 +1,5 @@
FROM openjdk:8-jdk-alpine
ARG JAR_FILE=build/libs/*.jar
COPY ${JAR_FILE} app.jar
ENTRYPOINT ["java","-jar","/app.jar"]
EXPOSE 8080

View File

@@ -0,0 +1,40 @@
# RDS Hello World Application
This is a simple Spring Boot application which requires access to a PostgreSQL database.
The application has a single endpoint `/hello` which prints out if the database connection was successful.
Get it in a Docker image via `docker pull reflectoring/aws-rds-hello-world`.
Use the image instead of your real application to test AWS CloudFormation stacks which need access to a database.
## Testing AWS RDS connectivity with this application
1. Create an RDS PostgreSQL database with the AWS console.
2. Note the endpoint of your RDS database in the AWS console.
3. Deploy the Docker container `reflectoring/aws-rds-hello-world` into AWS instead of your real application (this could be via a CloudFormation stack, manually, or however you are deploying your app).
4. Configure your deployment in a way that Docker will pass the coordinates to your RDS database as environment variables, equivalent to this command:
```
docker run \
-e SPRING_DATASOURCE_URL=':'<RDS-ENDPOINT>:5432/postgres \
-e SPRING_DATASOURCE_USERNAME=<USERNAME> \
-e SPRING_DATASOURCE_PASSWORD=<PASSWORD> \
-p 8080:8080 reflectoring/aws-rds-hello-world
```
5. If the Spring Boot application can connect to the database, it will start up sucessfully and serve a message on the endpoint `/hello`.
# AWS Hello World
A simple Spring Boot application you can use to test deployments to AWS (or any other cloud provider, for that matter).
This application is also available as a Docker image on Docker Hub: [https://hub.docker.com/r/reflectoring/aws-hello-world](https://hub.docker.com/r/reflectoring/aws-hello-world).
## Blog posts
Blog posts about this topic:
* [The AWS Journey Part 1: Deploying Your First Docker Image](https://reflectoring.io/aws-deploy-docker-image-via-web-console/)
* [The AWS Journey Part 2: Deploying a Docker Image with AWS CloudFormation](https://reflectoring.io/aws-cloudformation-deploy-docker-image/)
* [The AWS Journey Part 3: Connecting a Spring Boot Application to an RDS Instance with CloudFormation](https://reflectoring.io/aws-cloudformation-rds/)
* [The AWS Journey Part 4: Zero-Downtime Deployment with CloudFormation and ECS](https://reflectoring.io/aws-cloudformation-ecs-deployment/)

View File

@@ -0,0 +1,31 @@
plugins {
id 'org.springframework.boot' version '2.2.4.RELEASE'
id 'io.spring.dependency-management' version '1.0.9.RELEASE'
id 'java'
}
group = 'io.reflectoring'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '1.8'
repositories {
mavenCentral()
}
dependencies {
implementation 'org.springframework.boot:spring-boot-starter-web'
// database
implementation 'org.flywaydb:flyway-core'
implementation 'org.springframework.boot:spring-boot-starter-data-jdbc'
runtimeOnly 'org.postgresql:postgresql'
testRuntimeOnly 'org.postgresql:postgresql'
testImplementation('org.springframework.boot:spring-boot-starter-test') {
exclude group: 'org.junit.vintage', module: 'junit-vintage-engine'
}
}
test {
useJUnitPlatform()
}

View File

@@ -0,0 +1,18 @@
version: '3.7'
services:
postgres:
container_name: "rds-hello-world"
image: postgres
volumes:
- rds-hello-world:/var/lib/postgresql/data
ports:
- 5432:5432
environment:
- POSTGRES_USER=hello
- POSTGRES_PASSWORD=hello
volumes:
rds-hello-world:
driver: local

Binary file not shown.

View File

@@ -1,5 +1,5 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-6.5-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-4.10.1-bin.zip

0
solid/gradlew → aws/aws-rds-hello-world/gradlew vendored Normal file → Executable file
View File

0
solid/gradlew.bat → aws/aws-rds-hello-world/gradlew.bat vendored Normal file → Executable file
View File

View File

@@ -0,0 +1 @@
rootProject.name = 'aws-rds-hello-world'

View File

@@ -0,0 +1,13 @@
package io.reflectoring.awshelloworld;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class AwsHelloWorldApplication {
public static void main(String[] args) {
SpringApplication.run(AwsHelloWorldApplication.class, args);
}
}

View File

@@ -0,0 +1,23 @@
package io.reflectoring.awshelloworld;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
class HelloWorldController {
private final UserRepository userRepository;
HelloWorldController(UserRepository userRepository) {
this.userRepository = userRepository;
}
@GetMapping("/hello")
String helloWorld(){
Iterable<User> users = userRepository.findAll();
return "Hello AWS! Successfully connected to the database!";
}
}

View File

@@ -0,0 +1,38 @@
package io.reflectoring.awshelloworld;
import org.springframework.data.annotation.Id;
import org.springframework.data.relational.core.mapping.Table;
@Table("hello_user")
public class User {
@Id
private Long id;
private String name;
public User(Long id, String name) {
this.id = id;
this.name = name;
}
public User() {
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}

View File

@@ -0,0 +1,6 @@
package io.reflectoring.awshelloworld;
import org.springframework.data.repository.CrudRepository;
public interface UserRepository extends CrudRepository<User, Long> {
}

View File

@@ -0,0 +1,5 @@
spring:
datasource:
url: jdbc:postgresql://localhost:5432/hello
username: hello
password: hello

View File

@@ -0,0 +1,5 @@
create table hello_user (
id varchar(36) not null unique,
name varchar(100) not null,
primary key(id)
);

View File

@@ -0,0 +1,11 @@
# Terraform for creating AWS Resources
Example code to create/update AWS resources with Terraform.
Examples include Terraform capabilities of using modules, input variables and using Terraform cloud.
## Blog posts
Blog posts about this topic:
* [Using Terraform to create AWS resources](https://reflectoring.io/terraform-aws/)

View File

@@ -0,0 +1,41 @@
terraform {
backend "remote" {
hostname = "app.terraform.io"
organization = "pratikorg"
token = "pj7p59JFwSC4jQ.atlasv1.qfmTxLjTfaM5zKyaQrcGzuTojv6oCyLIoIAO7DkA2ieQY7OyINjINGGMiTczt62p1bs"
workspaces {
name = "my-tf-workspace"
}
}
required_providers {
aws = {
source = "hashicorp/aws"
version = "~> 3.36"
}
}
}
provider "aws" {
profile = "default"
region = "us-west-2"
}
module "app_server" {
source = "./modules/application"
ec2_instance_type = "t2.micro"
ami = "ami-830c94e3"
tags = {
Name = "server for web"
Env = "dev"
}
}
module "app_storage" {
source = "./modules/storage/"
bucket_name = "io.pratik.tf-example-bucket"
env = "dev"
}

View File

@@ -0,0 +1,5 @@
resource "aws_instance" "vm-web" {
ami = var.ami
instance_type = var.ec2_instance_type
tags = var.tags
}

View File

@@ -0,0 +1,4 @@
output "instanceID" {
description = "ID of ec2 instance"
value = aws_instance.vm-web.id
}

View File

@@ -0,0 +1,16 @@
variable "ec2_instance_type" {
description = "Instance type"
type = string
}
variable "ami" {
description = "ami id"
type = string
}
variable "tags" {
description = "Tags to set on the bucket."
type = map(string)
default = {Name = "server for web"
Env = "dev"}
}

View File

@@ -0,0 +1,9 @@
resource "aws_s3_bucket" "s3_bucket" {
bucket = format("%s-%s",var.bucket_name,var.env)
acl = "private"
tags = {
Name = var.bucket_name
Environment = var.env
}
}

View File

@@ -0,0 +1,4 @@
output "arn" {
description = "ARN of the bucket"
value = aws_s3_bucket.s3_bucket.arn
}

View File

@@ -0,0 +1,13 @@
# Input variable definitions
variable "bucket_name" {
description = "Name of bucket"
type = string
}
variable "env" {
description = "Environment like dev, prod"
type = string
}

View File

@@ -0,0 +1,24 @@
terraform {
required_providers {
aws = {
source = "hashicorp/aws"
version = "~> 3.27"
}
}
}
provider "aws" {
profile = "default"
region = "us-west-2"
}
resource "aws_instance" "vm-web" {
ami = "ami-830c94e3"
instance_type = var.ec2_instance_type
tags = {
Name = "server for web"
Env = "dev"
}
}

View File

@@ -0,0 +1 @@
ec2_instance_type = "t2.micro"

View File

@@ -0,0 +1,4 @@
variable "ec2_instance_type" {
description = "AWS EC2 instance type."
type = string
}

View File

@@ -0,0 +1,33 @@
terraform {
required_providers {
aws = {
source = "hashicorp/aws"
version = "~> 3.36"
}
}
}
provider "aws" {
profile = "default"
region = "us-west-2"
}
module "app_server" {
source = "./modules/application"
ec2_instance_type = "t2.micro"
ami = "ami-830c94e3"
tags = {
Name = "server for web"
Env = "dev"
}
}
module "app_storage" {
source = "./modules/storage/"
bucket_name = "io.pratik.tf-example-bucket"
env = "dev"
}

View File

@@ -0,0 +1,5 @@
resource "aws_instance" "vm-web" {
ami = var.ami
instance_type = var.ec2_instance_type
tags = var.tags
}

View File

@@ -0,0 +1,4 @@
output "instanceID" {
description = "ID of ec2 instance"
value = aws_instance.vm-web.id
}

View File

@@ -0,0 +1,16 @@
variable "ec2_instance_type" {
description = "Instance type"
type = string
}
variable "ami" {
description = "ami id"
type = string
}
variable "tags" {
description = "Tags to set on the bucket."
type = map(string)
default = {Name = "server for web"
Env = "dev"}
}

View File

@@ -0,0 +1,9 @@
resource "aws_s3_bucket" "s3_bucket" {
bucket = format("%s-%s",var.bucket_name,var.env)
acl = "private"
tags = {
Name = var.bucket_name
Environment = var.env
}
}

View File

@@ -0,0 +1,4 @@
output "arn" {
description = "ARN of the bucket"
value = aws_s3_bucket.s3_bucket.arn
}

View File

@@ -0,0 +1,13 @@
# Input variable definitions
variable "bucket_name" {
description = "Name of bucket"
type = string
}
variable "env" {
description = "Environment like dev, prod"
type = string
}

View File

@@ -0,0 +1,24 @@
terraform {
required_providers {
aws = {
source = "hashicorp/aws"
version = "~> 3.27"
}
}
}
provider "aws" {
profile = "default"
region = "us-west-2"
}
resource "aws_instance" "vm-web" {
ami = "ami-830c94e3"
instance_type = "t2.micro"
tags = {
Name = "server for web"
Env = "dev"
}
}

View File

@@ -0,0 +1,117 @@
/*
* Copyright 2007-present the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.net.*;
import java.io.*;
import java.nio.channels.*;
import java.util.Properties;
public class MavenWrapperDownloader {
private static final String WRAPPER_VERSION = "0.5.6";
/**
* Default URL to download the maven-wrapper.jar from, if no 'downloadUrl' is provided.
*/
private static final String DEFAULT_DOWNLOAD_URL = "https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/"
+ WRAPPER_VERSION + "/maven-wrapper-" + WRAPPER_VERSION + ".jar";
/**
* Path to the maven-wrapper.properties file, which might contain a downloadUrl property to
* use instead of the default one.
*/
private static final String MAVEN_WRAPPER_PROPERTIES_PATH =
".mvn/wrapper/maven-wrapper.properties";
/**
* Path where the maven-wrapper.jar will be saved to.
*/
private static final String MAVEN_WRAPPER_JAR_PATH =
".mvn/wrapper/maven-wrapper.jar";
/**
* Name of the property which should be used to override the default download url for the wrapper.
*/
private static final String PROPERTY_NAME_WRAPPER_URL = "wrapperUrl";
public static void main(String args[]) {
System.out.println("- Downloader started");
File baseDirectory = new File(args[0]);
System.out.println("- Using base directory: " + baseDirectory.getAbsolutePath());
// If the maven-wrapper.properties exists, read it and check if it contains a custom
// wrapperUrl parameter.
File mavenWrapperPropertyFile = new File(baseDirectory, MAVEN_WRAPPER_PROPERTIES_PATH);
String url = DEFAULT_DOWNLOAD_URL;
if(mavenWrapperPropertyFile.exists()) {
FileInputStream mavenWrapperPropertyFileInputStream = null;
try {
mavenWrapperPropertyFileInputStream = new FileInputStream(mavenWrapperPropertyFile);
Properties mavenWrapperProperties = new Properties();
mavenWrapperProperties.load(mavenWrapperPropertyFileInputStream);
url = mavenWrapperProperties.getProperty(PROPERTY_NAME_WRAPPER_URL, url);
} catch (IOException e) {
System.out.println("- ERROR loading '" + MAVEN_WRAPPER_PROPERTIES_PATH + "'");
} finally {
try {
if(mavenWrapperPropertyFileInputStream != null) {
mavenWrapperPropertyFileInputStream.close();
}
} catch (IOException e) {
// Ignore ...
}
}
}
System.out.println("- Downloading from: " + url);
File outputFile = new File(baseDirectory.getAbsolutePath(), MAVEN_WRAPPER_JAR_PATH);
if(!outputFile.getParentFile().exists()) {
if(!outputFile.getParentFile().mkdirs()) {
System.out.println(
"- ERROR creating output directory '" + outputFile.getParentFile().getAbsolutePath() + "'");
}
}
System.out.println("- Downloading to: " + outputFile.getAbsolutePath());
try {
downloadFileFromURL(url, outputFile);
System.out.println("Done");
System.exit(0);
} catch (Throwable e) {
System.out.println("- Error downloading");
e.printStackTrace();
System.exit(1);
}
}
private static void downloadFileFromURL(String urlString, File destination) throws Exception {
if (System.getenv("MVNW_USERNAME") != null && System.getenv("MVNW_PASSWORD") != null) {
String username = System.getenv("MVNW_USERNAME");
char[] password = System.getenv("MVNW_PASSWORD").toCharArray();
Authenticator.setDefault(new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
}
URL website = new URL(urlString);
ReadableByteChannel rbc;
rbc = Channels.newChannel(website.openStream());
FileOutputStream fos = new FileOutputStream(destination);
fos.getChannel().transferFrom(rbc, 0, Long.MAX_VALUE);
fos.close();
rbc.close();
}
}

BIN
aws/cdk/.mvn/wrapper/maven-wrapper.jar vendored Normal file

Binary file not shown.

View File

@@ -0,0 +1,2 @@
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.6.3/apache-maven-3.6.3-bin.zip
wrapperUrl=https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar

182
aws/cdk/mvnw.cmd vendored Normal file
View File

@@ -0,0 +1,182 @@
@REM ----------------------------------------------------------------------------
@REM Licensed to the Apache Software Foundation (ASF) under one
@REM or more contributor license agreements. See the NOTICE file
@REM distributed with this work for additional information
@REM regarding copyright ownership. The ASF licenses this file
@REM to you under the Apache License, Version 2.0 (the
@REM "License"); you may not use this file except in compliance
@REM with the License. You may obtain a copy of the License at
@REM
@REM http://www.apache.org/licenses/LICENSE-2.0
@REM
@REM Unless required by applicable law or agreed to in writing,
@REM software distributed under the License is distributed on an
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
@REM KIND, either express or implied. See the License for the
@REM specific language governing permissions and limitations
@REM under the License.
@REM ----------------------------------------------------------------------------
@REM ----------------------------------------------------------------------------
@REM Maven Start Up Batch script
@REM
@REM Required ENV vars:
@REM JAVA_HOME - location of a JDK home dir
@REM
@REM Optional ENV vars
@REM M2_HOME - location of maven2's installed home dir
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
@REM e.g. to debug Maven itself, use
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
@REM ----------------------------------------------------------------------------
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
@echo off
@REM set title of command window
title %0
@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO%
@REM set %HOME% to equivalent of $HOME
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
@REM Execute a user defined script before this one
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
@REM check for pre script, once with legacy .bat ending and once with .cmd ending
if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat"
if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd"
:skipRcPre
@setlocal
set ERROR_CODE=0
@REM To isolate internal variables from possible post scripts, we use another setlocal
@setlocal
@REM ==== START VALIDATION ====
if not "%JAVA_HOME%" == "" goto OkJHome
echo.
echo Error: JAVA_HOME not found in your environment. >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
:OkJHome
if exist "%JAVA_HOME%\bin\java.exe" goto init
echo.
echo Error: JAVA_HOME is set to an invalid directory. >&2
echo JAVA_HOME = "%JAVA_HOME%" >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
@REM ==== END VALIDATION ====
:init
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
@REM Fallback to current working directory if not found.
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
set EXEC_DIR=%CD%
set WDIR=%EXEC_DIR%
:findBaseDir
IF EXIST "%WDIR%"\.mvn goto baseDirFound
cd ..
IF "%WDIR%"=="%CD%" goto baseDirNotFound
set WDIR=%CD%
goto findBaseDir
:baseDirFound
set MAVEN_PROJECTBASEDIR=%WDIR%
cd "%EXEC_DIR%"
goto endDetectBaseDir
:baseDirNotFound
set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
cd "%EXEC_DIR%"
:endDetectBaseDir
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
@setlocal EnableExtensions EnableDelayedExpansion
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
:endReadAdditionalConfig
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
FOR /F "tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B
)
@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
@REM This allows using the maven wrapper in projects that prohibit checking in binary data.
if exist %WRAPPER_JAR% (
if "%MVNW_VERBOSE%" == "true" (
echo Found %WRAPPER_JAR%
)
) else (
if not "%MVNW_REPOURL%" == "" (
SET DOWNLOAD_URL="%MVNW_REPOURL%/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
)
if "%MVNW_VERBOSE%" == "true" (
echo Couldn't find %WRAPPER_JAR%, downloading it ...
echo Downloading from: %DOWNLOAD_URL%
)
powershell -Command "&{"^
"$webclient = new-object System.Net.WebClient;"^
"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
"}"^
"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^
"}"
if "%MVNW_VERBOSE%" == "true" (
echo Finished downloading %WRAPPER_JAR%
)
)
@REM End of extension
@REM Provide a "standardized" way to retrieve the CLI args that will
@REM work with both Windows and non-Windows executions.
set MAVEN_CMD_LINE_ARGS=%*
%MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
if ERRORLEVEL 1 goto error
goto end
:error
set ERROR_CODE=1
:end
@endlocal & set ERROR_CODE=%ERROR_CODE%
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost
@REM check for post script, once with legacy .bat ending and once with .cmd ending
if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat"
if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd"
:skipRcPost
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
if "%MAVEN_BATCH_PAUSE%" == "on" pause
if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE%
exit /B %ERROR_CODE%

View File

@@ -0,0 +1,23 @@
package com.myorg;
import software.amazon.awscdk.core.Construct;
import software.amazon.awscdk.core.Stack;
import software.amazon.awscdk.core.StackProps;
import software.amazon.awscdk.services.s3.Bucket;
public class SecondStack extends Stack {
public SecondStack(final Construct scope, final String id) {
this(scope, id, null);
}
public SecondStack(final Construct scope, final String id, final StackProps props) {
super(scope, id, props);
String bucketName = (String) this.getNode().tryGetContext("bucketName2");
Bucket bucket = Bucket.Builder.create(this, "bucket")
.bucketName(bucketName)
.build();
}
}

View File

@@ -0,0 +1,117 @@
/*
* Copyright 2007-present the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.net.*;
import java.io.*;
import java.nio.channels.*;
import java.util.Properties;
public class MavenWrapperDownloader {
private static final String WRAPPER_VERSION = "0.5.6";
/**
* Default URL to download the maven-wrapper.jar from, if no 'downloadUrl' is provided.
*/
private static final String DEFAULT_DOWNLOAD_URL = "https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/"
+ WRAPPER_VERSION + "/maven-wrapper-" + WRAPPER_VERSION + ".jar";
/**
* Path to the maven-wrapper.properties file, which might contain a downloadUrl property to
* use instead of the default one.
*/
private static final String MAVEN_WRAPPER_PROPERTIES_PATH =
".mvn/wrapper/maven-wrapper.properties";
/**
* Path where the maven-wrapper.jar will be saved to.
*/
private static final String MAVEN_WRAPPER_JAR_PATH =
".mvn/wrapper/maven-wrapper.jar";
/**
* Name of the property which should be used to override the default download url for the wrapper.
*/
private static final String PROPERTY_NAME_WRAPPER_URL = "wrapperUrl";
public static void main(String args[]) {
System.out.println("- Downloader started");
File baseDirectory = new File(args[0]);
System.out.println("- Using base directory: " + baseDirectory.getAbsolutePath());
// If the maven-wrapper.properties exists, read it and check if it contains a custom
// wrapperUrl parameter.
File mavenWrapperPropertyFile = new File(baseDirectory, MAVEN_WRAPPER_PROPERTIES_PATH);
String url = DEFAULT_DOWNLOAD_URL;
if(mavenWrapperPropertyFile.exists()) {
FileInputStream mavenWrapperPropertyFileInputStream = null;
try {
mavenWrapperPropertyFileInputStream = new FileInputStream(mavenWrapperPropertyFile);
Properties mavenWrapperProperties = new Properties();
mavenWrapperProperties.load(mavenWrapperPropertyFileInputStream);
url = mavenWrapperProperties.getProperty(PROPERTY_NAME_WRAPPER_URL, url);
} catch (IOException e) {
System.out.println("- ERROR loading '" + MAVEN_WRAPPER_PROPERTIES_PATH + "'");
} finally {
try {
if(mavenWrapperPropertyFileInputStream != null) {
mavenWrapperPropertyFileInputStream.close();
}
} catch (IOException e) {
// Ignore ...
}
}
}
System.out.println("- Downloading from: " + url);
File outputFile = new File(baseDirectory.getAbsolutePath(), MAVEN_WRAPPER_JAR_PATH);
if(!outputFile.getParentFile().exists()) {
if(!outputFile.getParentFile().mkdirs()) {
System.out.println(
"- ERROR creating output directory '" + outputFile.getParentFile().getAbsolutePath() + "'");
}
}
System.out.println("- Downloading to: " + outputFile.getAbsolutePath());
try {
downloadFileFromURL(url, outputFile);
System.out.println("Done");
System.exit(0);
} catch (Throwable e) {
System.out.println("- Error downloading");
e.printStackTrace();
System.exit(1);
}
}
private static void downloadFileFromURL(String urlString, File destination) throws Exception {
if (System.getenv("MVNW_USERNAME") != null && System.getenv("MVNW_PASSWORD") != null) {
String username = System.getenv("MVNW_USERNAME");
char[] password = System.getenv("MVNW_PASSWORD").toCharArray();
Authenticator.setDefault(new Authenticator() {
@Override
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
}
URL website = new URL(urlString);
ReadableByteChannel rbc;
rbc = Channels.newChannel(website.openStream());
FileOutputStream fos = new FileOutputStream(destination);
fos.getChannel().transferFrom(rbc, 0, Long.MAX_VALUE);
fos.close();
rbc.close();
}
}

BIN
aws/cdkv2/.mvn/wrapper/maven-wrapper.jar vendored Normal file

Binary file not shown.

View File

@@ -0,0 +1,2 @@
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.6.3/apache-maven-3.6.3-bin.zip
wrapperUrl=https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar

8
aws/cdkv2/README.md Normal file
View File

@@ -0,0 +1,8 @@
# Getting started with AWS CDK
Blog posts about this topic:
* [Getting started with AWS CDK](https://reflectoring.io/getting-started-with-aws-cdk/)

View File

@@ -0,0 +1,51 @@
{
"vpc-provider:account=675153449441:filter.isDefault=true:region=us-east-1:returnAsymmetricSubnets=true": {
"vpcId": "vpc-e5e76998",
"vpcCidrBlock": "172.31.0.0/16",
"availabilityZones": [],
"subnetGroups": [
{
"name": "Public",
"type": "Public",
"subnets": [
{
"subnetId": "subnet-d71e66f6",
"cidr": "172.31.80.0/20",
"availabilityZone": "us-east-1a",
"routeTableId": "rtb-ed425793"
},
{
"subnetId": "subnet-1783815a",
"cidr": "172.31.16.0/20",
"availabilityZone": "us-east-1b",
"routeTableId": "rtb-ed425793"
},
{
"subnetId": "subnet-71d8a72e",
"cidr": "172.31.32.0/20",
"availabilityZone": "us-east-1c",
"routeTableId": "rtb-ed425793"
},
{
"subnetId": "subnet-7ee39118",
"cidr": "172.31.0.0/20",
"availabilityZone": "us-east-1d",
"routeTableId": "rtb-ed425793"
},
{
"subnetId": "subnet-a56bed94",
"cidr": "172.31.48.0/20",
"availabilityZone": "us-east-1e",
"routeTableId": "rtb-ed425793"
},
{
"subnetId": "subnet-cc1e2ac2",
"cidr": "172.31.64.0/20",
"availabilityZone": "us-east-1f",
"routeTableId": "rtb-ed425793"
}
]
}
]
}
}

27
aws/cdkv2/cdk.json Normal file
View File

@@ -0,0 +1,27 @@
{
"app": "mvn -e -q compile exec:java",
"watch": {
"include": [
"**"
],
"exclude": [
"README.md",
"cdk*.json",
"target",
"pom.xml",
"src/test"
]
},
"context": {
"@aws-cdk/aws-apigateway:usagePlanKeyOrderInsensitiveId": true,
"@aws-cdk/core:stackRelativeExports": true,
"@aws-cdk/aws-rds:lowercaseDbIdentifier": true,
"@aws-cdk/aws-lambda:recognizeVersionProps": true,
"@aws-cdk/aws-cloudfront:defaultSecurityPolicyTLSv1.2_2021": true,
"@aws-cdk-containers/ecs-service-extensions:enableDefaultLogDriver": true,
"@aws-cdk/core:target-partitions": [
"aws",
"aws-cn"
]
}
}

310
aws/cdkv2/mvnw vendored Executable file
View File

@@ -0,0 +1,310 @@
#!/bin/sh
# ----------------------------------------------------------------------------
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
# ----------------------------------------------------------------------------
# ----------------------------------------------------------------------------
# Maven Start Up Batch script
#
# Required ENV vars:
# ------------------
# JAVA_HOME - location of a JDK home dir
#
# Optional ENV vars
# -----------------
# M2_HOME - location of maven2's installed home dir
# MAVEN_OPTS - parameters passed to the Java VM when running Maven
# e.g. to debug Maven itself, use
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files
# ----------------------------------------------------------------------------
if [ -z "$MAVEN_SKIP_RC" ] ; then
if [ -f /etc/mavenrc ] ; then
. /etc/mavenrc
fi
if [ -f "$HOME/.mavenrc" ] ; then
. "$HOME/.mavenrc"
fi
fi
# OS specific support. $var _must_ be set to either true or false.
cygwin=false;
darwin=false;
mingw=false
case "`uname`" in
CYGWIN*) cygwin=true ;;
MINGW*) mingw=true;;
Darwin*) darwin=true
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html
if [ -z "$JAVA_HOME" ]; then
if [ -x "/usr/libexec/java_home" ]; then
export JAVA_HOME="`/usr/libexec/java_home`"
else
export JAVA_HOME="/Library/Java/Home"
fi
fi
;;
esac
if [ -z "$JAVA_HOME" ] ; then
if [ -r /etc/gentoo-release ] ; then
JAVA_HOME=`java-config --jre-home`
fi
fi
if [ -z "$M2_HOME" ] ; then
## resolve links - $0 may be a link to maven's home
PRG="$0"
# need this for relative symlinks
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG="`dirname "$PRG"`/$link"
fi
done
saveddir=`pwd`
M2_HOME=`dirname "$PRG"`/..
# make it fully qualified
M2_HOME=`cd "$M2_HOME" && pwd`
cd "$saveddir"
# echo Using m2 at $M2_HOME
fi
# For Cygwin, ensure paths are in UNIX format before anything is touched
if $cygwin ; then
[ -n "$M2_HOME" ] &&
M2_HOME=`cygpath --unix "$M2_HOME"`
[ -n "$JAVA_HOME" ] &&
JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
[ -n "$CLASSPATH" ] &&
CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
fi
# For Mingw, ensure paths are in UNIX format before anything is touched
if $mingw ; then
[ -n "$M2_HOME" ] &&
M2_HOME="`(cd "$M2_HOME"; pwd)`"
[ -n "$JAVA_HOME" ] &&
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
fi
if [ -z "$JAVA_HOME" ]; then
javaExecutable="`which javac`"
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
# readlink(1) is not available as standard on Solaris 10.
readLink=`which readlink`
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
if $darwin ; then
javaHome="`dirname \"$javaExecutable\"`"
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
else
javaExecutable="`readlink -f \"$javaExecutable\"`"
fi
javaHome="`dirname \"$javaExecutable\"`"
javaHome=`expr "$javaHome" : '\(.*\)/bin'`
JAVA_HOME="$javaHome"
export JAVA_HOME
fi
fi
fi
if [ -z "$JAVACMD" ] ; then
if [ -n "$JAVA_HOME" ] ; then
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
# IBM's JDK on AIX uses strange locations for the executables
JAVACMD="$JAVA_HOME/jre/sh/java"
else
JAVACMD="$JAVA_HOME/bin/java"
fi
else
JAVACMD="`which java`"
fi
fi
if [ ! -x "$JAVACMD" ] ; then
echo "Error: JAVA_HOME is not defined correctly." >&2
echo " We cannot execute $JAVACMD" >&2
exit 1
fi
if [ -z "$JAVA_HOME" ] ; then
echo "Warning: JAVA_HOME environment variable is not set."
fi
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
# traverses directory structure from process work directory to filesystem root
# first directory with .mvn subdirectory is considered project base directory
find_maven_basedir() {
if [ -z "$1" ]
then
echo "Path not specified to find_maven_basedir"
return 1
fi
basedir="$1"
wdir="$1"
while [ "$wdir" != '/' ] ; do
if [ -d "$wdir"/.mvn ] ; then
basedir=$wdir
break
fi
# workaround for JBEAP-8937 (on Solaris 10/Sparc)
if [ -d "${wdir}" ]; then
wdir=`cd "$wdir/.."; pwd`
fi
# end of workaround
done
echo "${basedir}"
}
# concatenates all lines of a file
concat_lines() {
if [ -f "$1" ]; then
echo "$(tr -s '\n' ' ' < "$1")"
fi
}
BASE_DIR=`find_maven_basedir "$(pwd)"`
if [ -z "$BASE_DIR" ]; then
exit 1;
fi
##########################################################################################
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
# This allows using the maven wrapper in projects that prohibit checking in binary data.
##########################################################################################
if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found .mvn/wrapper/maven-wrapper.jar"
fi
else
if [ "$MVNW_VERBOSE" = true ]; then
echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
fi
if [ -n "$MVNW_REPOURL" ]; then
jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
else
jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
fi
while IFS="=" read key value; do
case "$key" in (wrapperUrl) jarUrl="$value"; break ;;
esac
done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties"
if [ "$MVNW_VERBOSE" = true ]; then
echo "Downloading from: $jarUrl"
fi
wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar"
if $cygwin; then
wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"`
fi
if command -v wget > /dev/null; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found wget ... using wget"
fi
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
wget "$jarUrl" -O "$wrapperJarPath"
else
wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath"
fi
elif command -v curl > /dev/null; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found curl ... using curl"
fi
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
curl -o "$wrapperJarPath" "$jarUrl" -f
else
curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f
fi
else
if [ "$MVNW_VERBOSE" = true ]; then
echo "Falling back to using Java to download"
fi
javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java"
# For Cygwin, switch paths to Windows format before running javac
if $cygwin; then
javaClass=`cygpath --path --windows "$javaClass"`
fi
if [ -e "$javaClass" ]; then
if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
if [ "$MVNW_VERBOSE" = true ]; then
echo " - Compiling MavenWrapperDownloader.java ..."
fi
# Compiling the Java class
("$JAVA_HOME/bin/javac" "$javaClass")
fi
if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
# Running the downloader
if [ "$MVNW_VERBOSE" = true ]; then
echo " - Running MavenWrapperDownloader.java ..."
fi
("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR")
fi
fi
fi
fi
##########################################################################################
# End of extension
##########################################################################################
export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}
if [ "$MVNW_VERBOSE" = true ]; then
echo $MAVEN_PROJECTBASEDIR
fi
MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
# For Cygwin, switch paths to Windows format before running java
if $cygwin; then
[ -n "$M2_HOME" ] &&
M2_HOME=`cygpath --path --windows "$M2_HOME"`
[ -n "$JAVA_HOME" ] &&
JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
[ -n "$CLASSPATH" ] &&
CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
[ -n "$MAVEN_PROJECTBASEDIR" ] &&
MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"`
fi
# Provide a "standardized" way to retrieve the CLI args that will
# work with both Windows and non-Windows executions.
MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
export MAVEN_CMD_LINE_ARGS
WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
exec "$JAVACMD" \
$MAVEN_OPTS \
-classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
"-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"

182
aws/cdkv2/mvnw.cmd vendored Normal file
View File

@@ -0,0 +1,182 @@
@REM ----------------------------------------------------------------------------
@REM Licensed to the Apache Software Foundation (ASF) under one
@REM or more contributor license agreements. See the NOTICE file
@REM distributed with this work for additional information
@REM regarding copyright ownership. The ASF licenses this file
@REM to you under the Apache License, Version 2.0 (the
@REM "License"); you may not use this file except in compliance
@REM with the License. You may obtain a copy of the License at
@REM
@REM http://www.apache.org/licenses/LICENSE-2.0
@REM
@REM Unless required by applicable law or agreed to in writing,
@REM software distributed under the License is distributed on an
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
@REM KIND, either express or implied. See the License for the
@REM specific language governing permissions and limitations
@REM under the License.
@REM ----------------------------------------------------------------------------
@REM ----------------------------------------------------------------------------
@REM Maven Start Up Batch script
@REM
@REM Required ENV vars:
@REM JAVA_HOME - location of a JDK home dir
@REM
@REM Optional ENV vars
@REM M2_HOME - location of maven2's installed home dir
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
@REM e.g. to debug Maven itself, use
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
@REM ----------------------------------------------------------------------------
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
@echo off
@REM set title of command window
title %0
@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO%
@REM set %HOME% to equivalent of $HOME
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
@REM Execute a user defined script before this one
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
@REM check for pre script, once with legacy .bat ending and once with .cmd ending
if exist "%HOME%\mavenrc_pre.bat" call "%HOME%\mavenrc_pre.bat"
if exist "%HOME%\mavenrc_pre.cmd" call "%HOME%\mavenrc_pre.cmd"
:skipRcPre
@setlocal
set ERROR_CODE=0
@REM To isolate internal variables from possible post scripts, we use another setlocal
@setlocal
@REM ==== START VALIDATION ====
if not "%JAVA_HOME%" == "" goto OkJHome
echo.
echo Error: JAVA_HOME not found in your environment. >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
:OkJHome
if exist "%JAVA_HOME%\bin\java.exe" goto init
echo.
echo Error: JAVA_HOME is set to an invalid directory. >&2
echo JAVA_HOME = "%JAVA_HOME%" >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
@REM ==== END VALIDATION ====
:init
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
@REM Fallback to current working directory if not found.
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
set EXEC_DIR=%CD%
set WDIR=%EXEC_DIR%
:findBaseDir
IF EXIST "%WDIR%"\.mvn goto baseDirFound
cd ..
IF "%WDIR%"=="%CD%" goto baseDirNotFound
set WDIR=%CD%
goto findBaseDir
:baseDirFound
set MAVEN_PROJECTBASEDIR=%WDIR%
cd "%EXEC_DIR%"
goto endDetectBaseDir
:baseDirNotFound
set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
cd "%EXEC_DIR%"
:endDetectBaseDir
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
@setlocal EnableExtensions EnableDelayedExpansion
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
:endReadAdditionalConfig
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
FOR /F "tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B
)
@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
@REM This allows using the maven wrapper in projects that prohibit checking in binary data.
if exist %WRAPPER_JAR% (
if "%MVNW_VERBOSE%" == "true" (
echo Found %WRAPPER_JAR%
)
) else (
if not "%MVNW_REPOURL%" == "" (
SET DOWNLOAD_URL="%MVNW_REPOURL%/io/takari/maven-wrapper/0.5.6/maven-wrapper-0.5.6.jar"
)
if "%MVNW_VERBOSE%" == "true" (
echo Couldn't find %WRAPPER_JAR%, downloading it ...
echo Downloading from: %DOWNLOAD_URL%
)
powershell -Command "&{"^
"$webclient = new-object System.Net.WebClient;"^
"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
"}"^
"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^
"}"
if "%MVNW_VERBOSE%" == "true" (
echo Finished downloading %WRAPPER_JAR%
)
)
@REM End of extension
@REM Provide a "standardized" way to retrieve the CLI args that will
@REM work with both Windows and non-Windows executions.
set MAVEN_CMD_LINE_ARGS=%*
%MAVEN_JAVA_EXE% %JVM_CONFIG_MAVEN_PROPS% %MAVEN_OPTS% %MAVEN_DEBUG_OPTS% -classpath %WRAPPER_JAR% "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
if ERRORLEVEL 1 goto error
goto end
:error
set ERROR_CODE=1
:end
@endlocal & set ERROR_CODE=%ERROR_CODE%
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPost
@REM check for post script, once with legacy .bat ending and once with .cmd ending
if exist "%HOME%\mavenrc_post.bat" call "%HOME%\mavenrc_post.bat"
if exist "%HOME%\mavenrc_post.cmd" call "%HOME%\mavenrc_post.cmd"
:skipRcPost
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
if "%MAVEN_BATCH_PAUSE%" == "on" pause
if "%MAVEN_TERMINATE_CMD%" == "on" exit %ERROR_CODE%
exit /B %ERROR_CODE%

61
aws/cdkv2/pom.xml Normal file
View File

@@ -0,0 +1,61 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<modelVersion>4.0.0</modelVersion>
<groupId>com.myorg</groupId>
<artifactId>cdk-app</artifactId>
<version>0.1</version>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<cdk.version>2.8.0</cdk.version>
<constructs.version>[10.0.0,11.0.0)</constructs.version>
<junit.version>5.7.1</junit.version>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>3.0.0</version>
<configuration>
<mainClass>com.myorg.CdkAppApp</mainClass>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<!-- AWS Cloud Development Kit -->
<dependency>
<groupId>software.amazon.awscdk</groupId>
<artifactId>aws-cdk-lib</artifactId>
<version>${cdk.version}</version>
</dependency>
<dependency>
<groupId>software.constructs</groupId>
<artifactId>constructs</artifactId>
<version>${constructs.version}</version>
</dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter</artifactId>
<version>${junit.version}</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>

View File

@@ -0,0 +1,25 @@
package com.myorg;
import software.amazon.awscdk.App;
import software.amazon.awscdk.Environment;
import software.amazon.awscdk.StackProps;
import java.util.Arrays;
public class CdkAppApp {
public static void main(final String[] args) {
App app = new App();
new CdkAppStack(app, "CdkAppStack", StackProps.builder()
.env(Environment.builder()
.account("**********")
.region("us-east-1")
.build())
.build());
app.synth();
}
}

View File

@@ -0,0 +1,63 @@
package com.myorg;
import java.util.List;
import org.jetbrains.annotations.NotNull;
import software.amazon.awscdk.Stack;
import software.amazon.awscdk.StackProps;
import software.amazon.awscdk.services.ec2.BlockDeviceVolume;
import software.amazon.awscdk.services.ec2.BlockDevice;
import software.amazon.awscdk.services.ec2.IMachineImage;
import software.amazon.awscdk.services.ec2.IVpc;
import software.amazon.awscdk.services.ec2.Instance;
import software.amazon.awscdk.services.ec2.InstanceClass;
import software.amazon.awscdk.services.ec2.InstanceSize;
import software.amazon.awscdk.services.ec2.InstanceType;
import software.amazon.awscdk.services.ec2.MachineImage;
import software.amazon.awscdk.services.ec2.SecurityGroup;
import software.amazon.awscdk.services.ec2.Vpc;
import software.amazon.awscdk.services.ec2.VpcLookupOptions;
import software.constructs.Construct;
// import software.amazon.awscdk.Duration;
// import software.amazon.awscdk.services.sqs.Queue;
public class CdkAppStack extends Stack {
public CdkAppStack(final Construct scope, final String id) {
this(scope, id, null);
}
public CdkAppStack(final Construct scope, final String id, final StackProps props) {
super(scope, id, props);
VpcLookupOptions options = VpcLookupOptions.builder().isDefault(true).build();
IVpc vpc = Vpc.fromLookup(this, "vpc", options);
SecurityGroup securityGroup = SecurityGroup
.Builder
.create(this, "sg")
.vpc(vpc)
.allowAllOutbound(true)
.build();
Instance.Builder.create(this, "Instance")
.vpc(vpc)
.instanceType(InstanceType.of(InstanceClass.BURSTABLE2, InstanceSize.MICRO))
.machineImage(MachineImage.latestAmazonLinux())
.blockDevices(List.of(BlockDevice.builder()
.deviceName("/dev/sda1")
.volume(BlockDeviceVolume.ebs(50))
.build(), BlockDevice.builder()
.deviceName("/dev/sdm")
.volume(BlockDeviceVolume.ebs(100))
.build()))
.securityGroup(securityGroup)
.build();
}
}

View File

@@ -0,0 +1,34 @@
/**
*
*/
package com.myorg;
import software.amazon.awscdk.Duration;
import software.amazon.awscdk.services.s3.Bucket;
import software.amazon.awscdk.services.s3.LifecycleRule;
import software.constructs.Construct;
/**
* @author pratikdas
*
*/
public class MyStorageBucket extends Construct{
public MyStorageBucket(final Construct scope, final String id) {
super(scope, id);
Bucket bucket = new Bucket(this, "mybucket");
LifecycleRule lifecycleRule = LifecycleRule.builder()
.abortIncompleteMultipartUploadAfter(Duration.minutes(30))
.enabled(false)
.expiration(Duration.minutes(30))
.expiredObjectDeleteMarker(false)
.id("id").build();
bucket.addLifecycleRule(lifecycleRule);
}
}

View File

@@ -0,0 +1,26 @@
// package com.myorg;
// import software.amazon.awscdk.App;
// import software.amazon.awscdk.assertions.Template;
// import java.io.IOException;
// import java.util.HashMap;
// import org.junit.jupiter.api.Test;
// example test. To run these tests, uncomment this file, along with the
// example resource in java/src/main/java/com/myorg/CdkAppStack.java
// public class CdkAppTest {
// @Test
// public void testStack() throws IOException {
// App app = new App();
// CdkAppStack stack = new CdkAppStack(app, "test");
// Template template = Template.fromStack(stack);
// template.hasResourceProperties("AWS::SQS::Queue", new HashMap<String, Number>() {{
// put("VisibilityTimeout", 300);
// }});
// }
// }

View File

@@ -0,0 +1,13 @@
# Overview
![ECS in two public subnets](ecs-in-two-public-subnets.svg)
## Blog posts
Blog posts about this topic:
* [The AWS Journey Part 1: Deploying Your First Docker Image](https://reflectoring.io/aws-deploy-docker-image-via-web-console/)
* [The AWS Journey Part 2: Deploying a Docker Image with AWS CloudFormation](https://reflectoring.io/aws-cloudformation-deploy-docker-image/)
* [The AWS Journey Part 3: Connecting a Spring Boot Application to an RDS Instance with CloudFormation](https://reflectoring.io/aws-cloudformation-rds/)
* [The AWS Journey Part 4: Zero-Downtime Deployment with CloudFormation and ECS](https://reflectoring.io/aws-cloudformation-ecs-deployment/)

View File

@@ -0,0 +1 @@
<mxfile modified="2020-04-30T21:28:18.347Z" host="app.diagrams.net" agent="5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.149 Safari/537.36" etag="X9Eef2gSXNvxkCnmY-_0" version="13.0.4" type="device"><diagram id="Ht1M8jgEwFfnCIfOTk4-" name="Page-1">7Vpbb+o4EP41PC7K/fLIrWcr9UiVWO05+4RM4garIc4aU6C/fseJc7ND6ekB9nQXVKmZsTMez3yf7TEM7Ml6/4WhfPWVxjgdWEa8H9jTgWWZphXCP6E5lBrPcEpFwkgsOzWKOXnFUmlI7ZbEeNPpyClNOcm7yohmGY54R4cYo7tutyeadkfNUYI1xTxCqa79RmK+qublhU3D75gkKzl0YPllwxpVneVMNisU011LZc8G9oRRysun9X6CUxG8Ki7le3dHWmvHGM74e15Y4cjav97736avy2fP+Rr/vVj+Vjn3gtKtnPGfjxPpMD9UUcgpyXgRSXcMf/DSxBi40DIR0tByFYUq+12FqUvCRlehyn5XYarmTWV8U3WwpdCkjnlDGd9oOQh/9phueUoyPKkxZ4AyYSgmkIsJTSkDXUYziN54xdcpSCY87laE43mOIhHVHfAFdE804xL1plXJMvDiHUBNLp7X+0QQbIh2G2eYMLrNiyHvAfe9rYuXPBKvc0afceXSwLItJwhMRwxE0lRx9QUzTgD6o5QkwiqnYhAkpRQ/cWER/CdZ8lBIU9uQPreGGI3G/jgAfYw2KxzL8EicwRB4fxTBZs0LWFAwXWPODtClesGTaJVrSQXeXUNMO5S6VYuTjiGVSC4GSW264Qs8SMr8AH3MUKPP43aZkkjQZ7vMML9R6fNTaYOjLSP8sGg6zwteSXffRzLQz8I7e+adj2n1OOdmmm0pTLPCoR1obKsZ2Gab6ZkFSC5COPvGtxvf/vt8c4Buftj6uL8A90xfI99sMgfFHLMXAshQqddzxNBS5468SeC1Q2oezZcKMCU7talzJMTvJsTvXf9MuycHVnip04arxX9geamA7hIeEvEwynNYDREnwK2qjVWNDxTFuhZogLIIs6oFXKvNaSntXT46bKhS94CWOH2kG1L4Yk+XlHO6PsnFCBIEvnQWn56FxB6iZqaLFCa2WFbz0JaBOzdwbef4OncGvMAZs4MX0w+GgQ6Yqmps48W3LgSX4DRc7kWwi13TQ2uRhmy5yYuIqCj5gjjeocMnAwmR81sk0v1+bHgXxUa9SrSw4esL+lWxodct5VL+B9o8vy+f6tZoW3difC2OIsZ+MDPa/JsSBobKlGeUiQioeZka7gQ2nJ4d46n4XAFRp843aJOX4Xgie+FH/4GH4Q3dsgiXx50xiH0HHxxtzgO2utatwGb07lx+z8blX6xKdm5o+3+gzXL/fbRZeo2oYQzHCa6CKxBBE5qhdNZo25nBWTwSN8kivymNnoUqXRZyleYCOYjxqp/cPODNO5LWO5R29nXcsSeQCmVOFtfggtizw/e28JcQoKqT4nTfbpwe2tIjZgTiKNDVKk7EfN9OMYSnAM5bgZWbBkw0wfzUwUPHTPvgXOGG4RSOcC9d5/ogIc09imq+wV+owM9Uap9yTvKl9t24YsdU6i9bvTEs56wZKgBaT/EnMOvdMPsRzJ6Eons1KFrqUvhhLAYKFs0rY1Ev8z8ZFveEf6/GhucWEkFqgCiEQ0u44NLpvhOu5UnpKng1TfXKyfgYXq1Tho7gFXIt6sm6m7yoPeqw7fYT7JhfWv/QUehSenBe8vQV3TfyXIU84dW4Y1ff+9VfjzjDIDDqj2LwvUxyHLdr1hOn6aNmfxFemc41eKVfWLx1mfUp76isH7+dqn9T0nwtUv1KxT7TxaaS7MDvu7vyw6FUtks81zlOrCMlHojNL2JK8DS/K7Jn/wA=</diagram></mxfile>

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 25 KiB

View File

@@ -0,0 +1,247 @@
AWSTemplateFormatVersion: '2010-09-09'
Description: A network stack for deploying containers in AWS ECS.
This stack creates a VPC with two public subnets and a loadbalancer to balance traffic between those subnets.
Derived from a template at https://github.com/nathanpeck/aws-cloudformation-fargate.
Resources:
VPC:
Type: AWS::EC2::VPC
Properties:
CidrBlock: '10.0.0.0/16'
PublicSubnetOne:
Type: AWS::EC2::Subnet
Properties:
AvailabilityZone:
Fn::Select:
- 0
- Fn::GetAZs: {Ref: 'AWS::Region'}
VpcId: !Ref 'VPC'
CidrBlock: '10.0.1.0/24'
MapPublicIpOnLaunch: true
PublicSubnetTwo:
Type: AWS::EC2::Subnet
Properties:
AvailabilityZone:
Fn::Select:
- 1
- Fn::GetAZs: {Ref: 'AWS::Region'}
VpcId: !Ref 'VPC'
CidrBlock: '10.0.2.0/24'
MapPublicIpOnLaunch: true
InternetGateway:
Type: AWS::EC2::InternetGateway
GatewayAttachement:
Type: AWS::EC2::VPCGatewayAttachment
Properties:
VpcId: !Ref 'VPC'
InternetGatewayId: !Ref 'InternetGateway'
PublicRouteTable:
Type: AWS::EC2::RouteTable
Properties:
VpcId: !Ref 'VPC'
PublicSubnetOneRouteTableAssociation:
Type: AWS::EC2::SubnetRouteTableAssociation
Properties:
SubnetId: !Ref PublicSubnetOne
RouteTableId: !Ref PublicRouteTable
PublicSubnetTwoRouteTableAssociation:
Type: AWS::EC2::SubnetRouteTableAssociation
Properties:
SubnetId: !Ref PublicSubnetTwo
RouteTableId: !Ref PublicRouteTable
PublicRoute:
Type: AWS::EC2::Route
DependsOn: GatewayAttachement
Properties:
RouteTableId: !Ref 'PublicRouteTable'
DestinationCidrBlock: '0.0.0.0/0'
GatewayId: !Ref 'InternetGateway'
PublicLoadBalancerSecurityGroup:
Type: AWS::EC2::SecurityGroup
Properties:
GroupDescription: Access to the public facing load balancer
VpcId: !Ref 'VPC'
SecurityGroupIngress:
# Allow access to ALB from anywhere on the internet
- CidrIp: 0.0.0.0/0
IpProtocol: -1
PublicLoadBalancer:
Type: AWS::ElasticLoadBalancingV2::LoadBalancer
Properties:
Scheme: internet-facing
Subnets:
# The load balancer is placed into the public subnets, so that traffic
# from the internet can reach the load balancer directly via the internet gateway
- !Ref PublicSubnetOne
- !Ref PublicSubnetTwo
SecurityGroups: [!Ref 'PublicLoadBalancerSecurityGroup']
DummyTargetGroupPublic:
Type: AWS::ElasticLoadBalancingV2::TargetGroup
Properties:
HealthCheckIntervalSeconds: 6
HealthCheckPath: /
HealthCheckProtocol: HTTP
HealthCheckTimeoutSeconds: 5
HealthyThresholdCount: 2
Name: "no-op"
Port: 80
Protocol: HTTP
UnhealthyThresholdCount: 2
VpcId: !Ref 'VPC'
PublicLoadBalancerListener:
Type: AWS::ElasticLoadBalancingV2::Listener
DependsOn:
- PublicLoadBalancer
Properties:
DefaultActions:
- TargetGroupArn: !Ref 'DummyTargetGroupPublic'
Type: 'forward'
LoadBalancerArn: !Ref 'PublicLoadBalancer'
Port: 80
Protocol: HTTP
ECSCluster:
Type: AWS::ECS::Cluster
ECSSecurityGroup:
Type: AWS::EC2::SecurityGroup
Properties:
GroupDescription: Access to the ECS containers
VpcId: !Ref 'VPC'
ECSSecurityGroupIngressFromPublicALB:
Type: AWS::EC2::SecurityGroupIngress
Properties:
Description: Ingress from the public ALB
GroupId: !Ref 'ECSSecurityGroup'
IpProtocol: -1
SourceSecurityGroupId: !Ref 'PublicLoadBalancerSecurityGroup'
ECSSecurityGroupIngressFromSelf:
Type: AWS::EC2::SecurityGroupIngress
Properties:
Description: Ingress from other containers in the same security group
GroupId: !Ref 'ECSSecurityGroup'
IpProtocol: -1
SourceSecurityGroupId: !Ref 'ECSSecurityGroup'
ECSRole:
Type: AWS::IAM::Role
Properties:
AssumeRolePolicyDocument:
Statement:
- Effect: Allow
Principal:
Service: [ecs.amazonaws.com]
Action: ['sts:AssumeRole']
Path: /
Policies:
- PolicyName: ecs-service
PolicyDocument:
Statement:
- Effect: Allow
Action:
# Rules which allow ECS to attach network interfaces to instances
# on your behalf in order for awsvpc networking mode to work right
- 'ec2:AttachNetworkInterface'
- 'ec2:CreateNetworkInterface'
- 'ec2:CreateNetworkInterfacePermission'
- 'ec2:DeleteNetworkInterface'
- 'ec2:DeleteNetworkInterfacePermission'
- 'ec2:Describe*'
- 'ec2:DetachNetworkInterface'
# Rules which allow ECS to update load balancers on your behalf
# with the information sabout how to send traffic to your containers
- 'elasticloadbalancing:DeregisterInstancesFromLoadBalancer'
- 'elasticloadbalancing:DeregisterTargets'
- 'elasticloadbalancing:Describe*'
- 'elasticloadbalancing:RegisterInstancesWithLoadBalancer'
- 'elasticloadbalancing:RegisterTargets'
Resource: '*'
ECSTaskExecutionRole:
Type: AWS::IAM::Role
Properties:
AssumeRolePolicyDocument:
Statement:
- Effect: Allow
Principal:
Service: [ecs-tasks.amazonaws.com]
Action: ['sts:AssumeRole']
Path: /
Policies:
- PolicyName: AmazonECSTaskExecutionRolePolicy
PolicyDocument:
Statement:
- Effect: Allow
Action:
# Allow the ECS Tasks to download images from ECR
- 'ecr:GetAuthorizationToken'
- 'ecr:BatchCheckLayerAvailability'
- 'ecr:GetDownloadUrlForLayer'
- 'ecr:BatchGetImage'
# Allow the ECS tasks to upload logs to CloudWatch
- 'logs:CreateLogStream'
- 'logs:PutLogEvents'
Resource: '*'
Outputs:
ClusterName:
Description: The name of the ECS cluster
Value: !Ref 'ECSCluster'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ClusterName' ] ]
ExternalUrl:
Description: The url of the external load balancer
Value: !Join ['', ['http://', !GetAtt 'PublicLoadBalancer.DNSName']]
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ExternalUrl' ] ]
ECSRole:
Description: The ARN of the ECS role
Value: !GetAtt 'ECSRole.Arn'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ECSRole' ] ]
ECSTaskExecutionRole:
Description: The ARN of the ECS role
Value: !GetAtt 'ECSTaskExecutionRole.Arn'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ECSTaskExecutionRole' ] ]
PublicListener:
Description: The ARN of the public load balancer's Listener
Value: !Ref PublicLoadBalancerListener
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PublicListener' ] ]
VPCId:
Description: The ID of the VPC that this stack is deployed in
Value: !Ref 'VPC'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'VPCId' ] ]
PublicSubnetOne:
Description: Public subnet one
Value: !Ref 'PublicSubnetOne'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PublicSubnetOne' ] ]
PublicSubnetTwo:
Description: Public subnet two
Value: !Ref 'PublicSubnetTwo'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PublicSubnetTwo' ] ]
ECSSecurityGroup:
Description: A security group used to allow ECS containers to receive traffic
Value: !Ref 'ECSSecurityGroup'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ECSSecurityGroup' ] ]

View File

@@ -0,0 +1,139 @@
AWSTemplateFormatVersion: '2010-09-09'
Description: Deploy a service on AWS Fargate, hosted in two public subnets and accessible via a public load balancer.
Derived from a template at https://github.com/nathanpeck/aws-cloudformation-fargate.
Parameters:
StackName:
Type: String
Description: The name of the networking stack that
these resources are put into.
ServiceName:
Type: String
Description: A human-readable name for the service.
HealthCheckPath:
Type: String
Default: /health
Description: Path to perform the healthcheck on each instance.
HealthCheckIntervalSeconds:
Type: Number
Default: 5
Description: Number of seconds to wait between each health check.
ImageUrl:
Type: String
Description: The url of a docker image that will handle incoming traffic.
ContainerPort:
Type: Number
Default: 80
Description: The port number the application inside the docker container
is binding to.
ContainerCpu:
Type: Number
Default: 256
Description: How much CPU to give the container. 1024 is 1 CPU.
ContainerMemory:
Type: Number
Default: 512
Description: How much memory in megabytes to give the container.
Path:
Type: String
Default: "*"
Description: A path on the public load balancer that this service
should be connected to.
DesiredCount:
Type: Number
Default: 2
Description: How many copies of the service task to run.
Resources:
TargetGroup:
Type: AWS::ElasticLoadBalancingV2::TargetGroup
Properties:
HealthCheckIntervalSeconds: !Ref 'HealthCheckIntervalSeconds'
HealthCheckPath: !Ref 'HealthCheckPath'
HealthCheckProtocol: HTTP
HealthCheckTimeoutSeconds: 5
HealthyThresholdCount: 2
TargetType: ip
Name: !Ref 'ServiceName'
Port: !Ref 'ContainerPort'
Protocol: HTTP
UnhealthyThresholdCount: 2
VpcId:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'VPCId']]
LoadBalancerRule:
Type: AWS::ElasticLoadBalancingV2::ListenerRule
Properties:
Actions:
- TargetGroupArn: !Ref 'TargetGroup'
Type: 'forward'
Conditions:
- Field: path-pattern
Values: [!Ref 'Path']
ListenerArn:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'PublicListener']]
Priority: 1
LogGroup:
Type: AWS::Logs::LogGroup
Properties:
LogGroupName: !Ref 'ServiceName'
RetentionInDays: 1
TaskDefinition:
Type: AWS::ECS::TaskDefinition
Properties:
Family: !Ref 'ServiceName'
Cpu: !Ref 'ContainerCpu'
Memory: !Ref 'ContainerMemory'
NetworkMode: awsvpc
RequiresCompatibilities:
- FARGATE
ExecutionRoleArn:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'ECSTaskExecutionRole']]
ContainerDefinitions:
- Name: !Ref 'ServiceName'
Cpu: !Ref 'ContainerCpu'
Memory: !Ref 'ContainerMemory'
Image: !Ref 'ImageUrl'
PortMappings:
- ContainerPort: !Ref 'ContainerPort'
LogConfiguration:
LogDriver: 'awslogs'
Options:
awslogs-group: !Ref 'ServiceName'
awslogs-region: !Ref AWS::Region
awslogs-stream-prefix: !Ref 'ServiceName'
Service:
Type: AWS::ECS::Service
DependsOn: LoadBalancerRule
Properties:
ServiceName: !Ref 'ServiceName'
Cluster:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'ClusterName']]
LaunchType: FARGATE
DeploymentConfiguration:
MaximumPercent: 200
MinimumHealthyPercent: 50
DesiredCount: !Ref 'DesiredCount'
NetworkConfiguration:
AwsvpcConfiguration:
AssignPublicIp: ENABLED
SecurityGroups:
- Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'ECSSecurityGroup']]
Subnets:
- Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'PublicSubnetOne']]
- Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'PublicSubnetTwo']]
TaskDefinition: !Ref 'TaskDefinition'
LoadBalancers:
- ContainerName: !Ref 'ServiceName'
ContainerPort: !Ref 'ContainerPort'
TargetGroupArn: !Ref 'TargetGroup'

View File

@@ -0,0 +1,15 @@
# Overview
![ECS Zero Downtime Deployment](ecs-in-two-public-subnets.svg)
## Blog posts
Blog posts about this topic:
* [The AWS Journey Part 1: Deploying Your First Docker Image](https://reflectoring.io/aws-deploy-docker-image-via-web-console/)
* [The AWS Journey Part 2: Deploying a Docker Image with AWS CloudFormation](https://reflectoring.io/aws-cloudformation-deploy-docker-image/)
* [The AWS Journey Part 3: Connecting a Spring Boot Application to an RDS Instance with CloudFormation](https://reflectoring.io/aws-cloudformation-rds/)
* [The AWS Journey Part 4: Zero-Downtime Deployment with CloudFormation and ECS](https://reflectoring.io/aws-cloudformation-ecs-deployment/)

View File

@@ -0,0 +1,18 @@
# Turning off the AWS pager so that the CLI doesn't open an editor for each command result
export AWS_PAGER=""
aws cloudformation create-change-set \
--change-set-name update-reflectoring-ecs-zero-downtime-deployment-service \
--stack-name reflectoring-ecs-zero-downtime-deployment-service \
--use-previous-template \
--parameters \
ParameterKey=StackName,ParameterValue=reflectoring-ecs-zero-downtime-deployment-network \
ParameterKey=ServiceName,ParameterValue=reflectoring-hello-world \
ParameterKey=ImageUrl,ParameterValue=docker.io/reflectoring/aws-hello-world:v4 \
ParameterKey=ContainerPort,ParameterValue=8080 \
ParameterKey=HealthCheckPath,ParameterValue=/hello \
ParameterKey=HealthCheckIntervalSeconds,ParameterValue=90
aws cloudformation describe-change-set \
--stack-name reflectoring-ecs-zero-downtime-deployment-service \
--change-set-name update-reflectoring-ecs-zero-downtime-deployment-service

View File

@@ -0,0 +1,22 @@
# Turning off the AWS pager so that the CLI doesn't open an editor for each command result
export AWS_PAGER=""
aws cloudformation create-stack \
--stack-name reflectoring-ecs-zero-downtime-deployment-network \
--template-body file://network.yml \
--capabilities CAPABILITY_IAM
aws cloudformation wait stack-create-complete --stack-name reflectoring-ecs-zero-downtime-deployment-network
aws cloudformation create-stack \
--stack-name reflectoring-ecs-zero-downtime-deployment-service \
--template-body file://service.yml \
--parameters \
ParameterKey=StackName,ParameterValue=reflectoring-ecs-zero-downtime-deployment-network \
ParameterKey=ServiceName,ParameterValue=reflectoring-hello-world \
ParameterKey=ImageUrl,ParameterValue=docker.io/reflectoring/aws-hello-world:v3 \
ParameterKey=ContainerPort,ParameterValue=8080 \
ParameterKey=HealthCheckPath,ParameterValue=/hello \
ParameterKey=HealthCheckIntervalSeconds,ParameterValue=90
aws cloudformation wait stack-create-complete --stack-name reflectoring-ecs-zero-downtime-deployment-service

View File

@@ -0,0 +1,8 @@
# Turning off the AWS pager so that the CLI doesn't open an editor for each command result
export AWS_PAGER=""
aws cloudformation delete-stack --stack-name reflectoring-ecs-zero-downtime-deployment-service
aws cloudformation wait stack-delete-complete --stack-name reflectoring-ecs-zero-downtime-deployment-service
aws cloudformation delete-stack --stack-name reflectoring-ecs-zero-downtime-deployment-network
aws cloudformation wait stack-delete-complete --stack-name reflectoring-ecs-zero-downtime-deployment-network

View File

@@ -0,0 +1 @@
<mxfile modified="2020-04-30T21:28:18.347Z" host="app.diagrams.net" agent="5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.149 Safari/537.36" etag="X9Eef2gSXNvxkCnmY-_0" version="13.0.4" type="device"><diagram id="Ht1M8jgEwFfnCIfOTk4-" name="Page-1">7Vpbb+o4EP41PC7K/fLIrWcr9UiVWO05+4RM4garIc4aU6C/fseJc7ND6ekB9nQXVKmZsTMez3yf7TEM7Ml6/4WhfPWVxjgdWEa8H9jTgWWZphXCP6E5lBrPcEpFwkgsOzWKOXnFUmlI7ZbEeNPpyClNOcm7yohmGY54R4cYo7tutyeadkfNUYI1xTxCqa79RmK+qublhU3D75gkKzl0YPllwxpVneVMNisU011LZc8G9oRRysun9X6CUxG8Ki7le3dHWmvHGM74e15Y4cjav97736avy2fP+Rr/vVj+Vjn3gtKtnPGfjxPpMD9UUcgpyXgRSXcMf/DSxBi40DIR0tByFYUq+12FqUvCRlehyn5XYarmTWV8U3WwpdCkjnlDGd9oOQh/9phueUoyPKkxZ4AyYSgmkIsJTSkDXUYziN54xdcpSCY87laE43mOIhHVHfAFdE804xL1plXJMvDiHUBNLp7X+0QQbIh2G2eYMLrNiyHvAfe9rYuXPBKvc0afceXSwLItJwhMRwxE0lRx9QUzTgD6o5QkwiqnYhAkpRQ/cWER/CdZ8lBIU9uQPreGGI3G/jgAfYw2KxzL8EicwRB4fxTBZs0LWFAwXWPODtClesGTaJVrSQXeXUNMO5S6VYuTjiGVSC4GSW264Qs8SMr8AH3MUKPP43aZkkjQZ7vMML9R6fNTaYOjLSP8sGg6zwteSXffRzLQz8I7e+adj2n1OOdmmm0pTLPCoR1obKsZ2Gab6ZkFSC5COPvGtxvf/vt8c4Buftj6uL8A90xfI99sMgfFHLMXAshQqddzxNBS5468SeC1Q2oezZcKMCU7talzJMTvJsTvXf9MuycHVnip04arxX9geamA7hIeEvEwynNYDREnwK2qjVWNDxTFuhZogLIIs6oFXKvNaSntXT46bKhS94CWOH2kG1L4Yk+XlHO6PsnFCBIEvnQWn56FxB6iZqaLFCa2WFbz0JaBOzdwbef4OncGvMAZs4MX0w+GgQ6Yqmps48W3LgSX4DRc7kWwi13TQ2uRhmy5yYuIqCj5gjjeocMnAwmR81sk0v1+bHgXxUa9SrSw4esL+lWxodct5VL+B9o8vy+f6tZoW3difC2OIsZ+MDPa/JsSBobKlGeUiQioeZka7gQ2nJ4d46n4XAFRp843aJOX4Xgie+FH/4GH4Q3dsgiXx50xiH0HHxxtzgO2utatwGb07lx+z8blX6xKdm5o+3+gzXL/fbRZeo2oYQzHCa6CKxBBE5qhdNZo25nBWTwSN8kivymNnoUqXRZyleYCOYjxqp/cPODNO5LWO5R29nXcsSeQCmVOFtfggtizw/e28JcQoKqT4nTfbpwe2tIjZgTiKNDVKk7EfN9OMYSnAM5bgZWbBkw0wfzUwUPHTPvgXOGG4RSOcC9d5/ogIc09imq+wV+owM9Uap9yTvKl9t24YsdU6i9bvTEs56wZKgBaT/EnMOvdMPsRzJ6Eons1KFrqUvhhLAYKFs0rY1Ev8z8ZFveEf6/GhucWEkFqgCiEQ0u44NLpvhOu5UnpKng1TfXKyfgYXq1Tho7gFXIt6sm6m7yoPeqw7fYT7JhfWv/QUehSenBe8vQV3TfyXIU84dW4Y1ff+9VfjzjDIDDqj2LwvUxyHLdr1hOn6aNmfxFemc41eKVfWLx1mfUp76isH7+dqn9T0nwtUv1KxT7TxaaS7MDvu7vyw6FUtks81zlOrCMlHojNL2JK8DS/K7Jn/wA=</diagram></mxfile>

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 25 KiB

View File

@@ -0,0 +1,8 @@
# Turning off the AWS pager so that the CLI doesn't open an editor for each command result
export AWS_PAGER=""
aws cloudformation execute-change-set \
--stack-name reflectoring-ecs-zero-downtime-deployment-service \
--change-set-name update-reflectoring-ecs-zero-downtime-deployment-service
aws cloudformation wait stack-update-complete --stack-name reflectoring-ecs-zero-downtime-deployment-service

View File

@@ -0,0 +1,247 @@
AWSTemplateFormatVersion: '2010-09-09'
Description: A network stack for deploying containers in AWS ECS.
This stack creates a VPC with two public subnets and a loadbalancer to balance traffic between those subnets.
Derived from a template at https://github.com/nathanpeck/aws-cloudformation-fargate.
Resources:
VPC:
Type: AWS::EC2::VPC
Properties:
CidrBlock: '10.0.0.0/16'
PublicSubnetOne:
Type: AWS::EC2::Subnet
Properties:
AvailabilityZone:
Fn::Select:
- 0
- Fn::GetAZs: {Ref: 'AWS::Region'}
VpcId: !Ref 'VPC'
CidrBlock: '10.0.1.0/24'
MapPublicIpOnLaunch: true
PublicSubnetTwo:
Type: AWS::EC2::Subnet
Properties:
AvailabilityZone:
Fn::Select:
- 1
- Fn::GetAZs: {Ref: 'AWS::Region'}
VpcId: !Ref 'VPC'
CidrBlock: '10.0.2.0/24'
MapPublicIpOnLaunch: true
InternetGateway:
Type: AWS::EC2::InternetGateway
GatewayAttachement:
Type: AWS::EC2::VPCGatewayAttachment
Properties:
VpcId: !Ref 'VPC'
InternetGatewayId: !Ref 'InternetGateway'
PublicRouteTable:
Type: AWS::EC2::RouteTable
Properties:
VpcId: !Ref 'VPC'
PublicSubnetOneRouteTableAssociation:
Type: AWS::EC2::SubnetRouteTableAssociation
Properties:
SubnetId: !Ref PublicSubnetOne
RouteTableId: !Ref PublicRouteTable
PublicSubnetTwoRouteTableAssociation:
Type: AWS::EC2::SubnetRouteTableAssociation
Properties:
SubnetId: !Ref PublicSubnetTwo
RouteTableId: !Ref PublicRouteTable
PublicRoute:
Type: AWS::EC2::Route
DependsOn: GatewayAttachement
Properties:
RouteTableId: !Ref 'PublicRouteTable'
DestinationCidrBlock: '0.0.0.0/0'
GatewayId: !Ref 'InternetGateway'
PublicLoadBalancerSecurityGroup:
Type: AWS::EC2::SecurityGroup
Properties:
GroupDescription: Access to the public facing load balancer
VpcId: !Ref 'VPC'
SecurityGroupIngress:
# Allow access to ALB from anywhere on the internet
- CidrIp: 0.0.0.0/0
IpProtocol: -1
PublicLoadBalancer:
Type: AWS::ElasticLoadBalancingV2::LoadBalancer
Properties:
Scheme: internet-facing
Subnets:
# The load balancer is placed into the public subnets, so that traffic
# from the internet can reach the load balancer directly via the internet gateway
- !Ref PublicSubnetOne
- !Ref PublicSubnetTwo
SecurityGroups: [!Ref 'PublicLoadBalancerSecurityGroup']
DummyTargetGroupPublic:
Type: AWS::ElasticLoadBalancingV2::TargetGroup
Properties:
HealthCheckIntervalSeconds: 6
HealthCheckPath: /
HealthCheckProtocol: HTTP
HealthCheckTimeoutSeconds: 5
HealthyThresholdCount: 2
Name: "no-op"
Port: 80
Protocol: HTTP
UnhealthyThresholdCount: 2
VpcId: !Ref 'VPC'
PublicLoadBalancerListener:
Type: AWS::ElasticLoadBalancingV2::Listener
DependsOn:
- PublicLoadBalancer
Properties:
DefaultActions:
- TargetGroupArn: !Ref 'DummyTargetGroupPublic'
Type: 'forward'
LoadBalancerArn: !Ref 'PublicLoadBalancer'
Port: 80
Protocol: HTTP
ECSCluster:
Type: AWS::ECS::Cluster
ECSSecurityGroup:
Type: AWS::EC2::SecurityGroup
Properties:
GroupDescription: Access to the ECS containers
VpcId: !Ref 'VPC'
ECSSecurityGroupIngressFromPublicALB:
Type: AWS::EC2::SecurityGroupIngress
Properties:
Description: Ingress from the public ALB
GroupId: !Ref 'ECSSecurityGroup'
IpProtocol: -1
SourceSecurityGroupId: !Ref 'PublicLoadBalancerSecurityGroup'
ECSSecurityGroupIngressFromSelf:
Type: AWS::EC2::SecurityGroupIngress
Properties:
Description: Ingress from other containers in the same security group
GroupId: !Ref 'ECSSecurityGroup'
IpProtocol: -1
SourceSecurityGroupId: !Ref 'ECSSecurityGroup'
ECSRole:
Type: AWS::IAM::Role
Properties:
AssumeRolePolicyDocument:
Statement:
- Effect: Allow
Principal:
Service: [ecs.amazonaws.com]
Action: ['sts:AssumeRole']
Path: /
Policies:
- PolicyName: ecs-service
PolicyDocument:
Statement:
- Effect: Allow
Action:
# Rules which allow ECS to attach network interfaces to instances
# on your behalf in order for awsvpc networking mode to work right
- 'ec2:AttachNetworkInterface'
- 'ec2:CreateNetworkInterface'
- 'ec2:CreateNetworkInterfacePermission'
- 'ec2:DeleteNetworkInterface'
- 'ec2:DeleteNetworkInterfacePermission'
- 'ec2:Describe*'
- 'ec2:DetachNetworkInterface'
# Rules which allow ECS to update load balancers on your behalf
# with the information sabout how to send traffic to your containers
- 'elasticloadbalancing:DeregisterInstancesFromLoadBalancer'
- 'elasticloadbalancing:DeregisterTargets'
- 'elasticloadbalancing:Describe*'
- 'elasticloadbalancing:RegisterInstancesWithLoadBalancer'
- 'elasticloadbalancing:RegisterTargets'
Resource: '*'
ECSTaskExecutionRole:
Type: AWS::IAM::Role
Properties:
AssumeRolePolicyDocument:
Statement:
- Effect: Allow
Principal:
Service: [ecs-tasks.amazonaws.com]
Action: ['sts:AssumeRole']
Path: /
Policies:
- PolicyName: AmazonECSTaskExecutionRolePolicy
PolicyDocument:
Statement:
- Effect: Allow
Action:
# Allow the ECS Tasks to download images from ECR
- 'ecr:GetAuthorizationToken'
- 'ecr:BatchCheckLayerAvailability'
- 'ecr:GetDownloadUrlForLayer'
- 'ecr:BatchGetImage'
# Allow the ECS tasks to upload logs to CloudWatch
- 'logs:CreateLogStream'
- 'logs:PutLogEvents'
Resource: '*'
Outputs:
ClusterName:
Description: The name of the ECS cluster
Value: !Ref 'ECSCluster'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ClusterName' ] ]
ExternalUrl:
Description: The url of the external load balancer
Value: !Join ['', ['http://', !GetAtt 'PublicLoadBalancer.DNSName']]
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ExternalUrl' ] ]
ECSRole:
Description: The ARN of the ECS role
Value: !GetAtt 'ECSRole.Arn'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ECSRole' ] ]
ECSTaskExecutionRole:
Description: The ARN of the ECS role
Value: !GetAtt 'ECSTaskExecutionRole.Arn'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ECSTaskExecutionRole' ] ]
PublicListener:
Description: The ARN of the public load balancer's Listener
Value: !Ref PublicLoadBalancerListener
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PublicListener' ] ]
VPCId:
Description: The ID of the VPC that this stack is deployed in
Value: !Ref 'VPC'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'VPCId' ] ]
PublicSubnetOne:
Description: Public subnet one
Value: !Ref 'PublicSubnetOne'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PublicSubnetOne' ] ]
PublicSubnetTwo:
Description: Public subnet two
Value: !Ref 'PublicSubnetTwo'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PublicSubnetTwo' ] ]
ECSSecurityGroup:
Description: A security group used to allow ECS containers to receive traffic
Value: !Ref 'ECSSecurityGroup'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ECSSecurityGroup' ] ]

View File

@@ -0,0 +1,139 @@
AWSTemplateFormatVersion: '2010-09-09'
Description: Deploy a service on AWS Fargate, hosted in two public subnets and accessible via a public load balancer.
Derived from a template at https://github.com/nathanpeck/aws-cloudformation-fargate.
Parameters:
StackName:
Type: String
Description: The name of the networking stack that
these resources are put into.
ServiceName:
Type: String
Description: A human-readable name for the service.
HealthCheckPath:
Type: String
Default: /health
Description: Path to perform the healthcheck on each instance.
HealthCheckIntervalSeconds:
Type: Number
Default: 5
Description: Number of seconds to wait between each health check.
ImageUrl:
Type: String
Description: The url of a docker image that will handle incoming traffic.
ContainerPort:
Type: Number
Default: 80
Description: The port number the application inside the docker container
is binding to.
ContainerCpu:
Type: Number
Default: 256
Description: How much CPU to give the container. 1024 is 1 CPU.
ContainerMemory:
Type: Number
Default: 512
Description: How much memory in megabytes to give the container.
Path:
Type: String
Default: "*"
Description: A path on the public load balancer that this service
should be connected to.
DesiredCount:
Type: Number
Default: 2
Description: How many copies of the service task to run.
Resources:
TargetGroup:
Type: AWS::ElasticLoadBalancingV2::TargetGroup
Properties:
HealthCheckIntervalSeconds: !Ref 'HealthCheckIntervalSeconds'
HealthCheckPath: !Ref 'HealthCheckPath'
HealthCheckProtocol: HTTP
HealthCheckTimeoutSeconds: 5
HealthyThresholdCount: 2
TargetType: ip
Name: !Ref 'ServiceName'
Port: !Ref 'ContainerPort'
Protocol: HTTP
UnhealthyThresholdCount: 2
VpcId:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'VPCId']]
LoadBalancerRule:
Type: AWS::ElasticLoadBalancingV2::ListenerRule
Properties:
Actions:
- TargetGroupArn: !Ref 'TargetGroup'
Type: 'forward'
Conditions:
- Field: path-pattern
Values: [!Ref 'Path']
ListenerArn:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'PublicListener']]
Priority: 1
LogGroup:
Type: AWS::Logs::LogGroup
Properties:
LogGroupName: !Ref 'ServiceName'
RetentionInDays: 1
TaskDefinition:
Type: AWS::ECS::TaskDefinition
Properties:
Family: !Ref 'ServiceName'
Cpu: !Ref 'ContainerCpu'
Memory: !Ref 'ContainerMemory'
NetworkMode: awsvpc
RequiresCompatibilities:
- FARGATE
ExecutionRoleArn:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'ECSTaskExecutionRole']]
ContainerDefinitions:
- Name: !Ref 'ServiceName'
Cpu: !Ref 'ContainerCpu'
Memory: !Ref 'ContainerMemory'
Image: !Ref 'ImageUrl'
PortMappings:
- ContainerPort: !Ref 'ContainerPort'
LogConfiguration:
LogDriver: 'awslogs'
Options:
awslogs-group: !Ref 'ServiceName'
awslogs-region: !Ref AWS::Region
awslogs-stream-prefix: !Ref 'ServiceName'
Service:
Type: AWS::ECS::Service
DependsOn: LoadBalancerRule
Properties:
ServiceName: !Ref 'ServiceName'
Cluster:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'ClusterName']]
LaunchType: FARGATE
DeploymentConfiguration:
MaximumPercent: 200
MinimumHealthyPercent: 50
DesiredCount: !Ref 'DesiredCount'
NetworkConfiguration:
AwsvpcConfiguration:
AssignPublicIp: ENABLED
SecurityGroups:
- Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'ECSSecurityGroup']]
Subnets:
- Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'PublicSubnetOne']]
- Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'PublicSubnetTwo']]
TaskDefinition: !Ref 'TaskDefinition'
LoadBalancers:
- ContainerName: !Ref 'ServiceName'
ContainerPort: !Ref 'ContainerPort'
TargetGroupArn: !Ref 'TargetGroup'

View File

@@ -0,0 +1,109 @@
AWSTemplateFormatVersion: '2010-09-09'
Description: Deploy a service on AWS Fargate, hosted in two public subnets and accessible via a public load balancer.
Derived from a template at https://github.com/nathanpeck/aws-cloudformation-fargate.
Parameters:
StackName:
Type: String
Description: The name of the networking stack that
these resources are put into.
ServiceName:
Type: String
Description: A human-readable name for the service.
HealthCheckPath:
Type: String
Default: /health
Description: Path to perform the healthcheck on each instance.
HealthCheckIntervalSeconds:
Type: Number
Default: 5
Description: Number of seconds to wait between each health check.
ImageUrl:
Type: String
Description: The url of a docker image that will handle incoming traffic.
ContainerPort:
Type: Number
Default: 80
Description: The port number the application inside the docker container
is binding to.
ContainerCpu:
Type: Number
Default: 256
Description: How much CPU to give the container. 1024 is 1 CPU.
ContainerMemory:
Type: Number
Default: 512
Description: How much memory in megabytes to give the container.
Path:
Type: String
Default: "*"
Description: A path on the public load balancer that this service
should be connected to.
DesiredCount:
Type: Number
Default: 2
Description: How many copies of the service task to run.
Resources:
TargetGroup:
Type: AWS::ElasticLoadBalancingV2::TargetGroup
Properties:
HealthCheckIntervalSeconds: !Ref 'HealthCheckIntervalSeconds'
HealthCheckPath: !Ref 'HealthCheckPath'
HealthCheckProtocol: HTTP
HealthCheckTimeoutSeconds: 5
HealthyThresholdCount: 2
TargetType: ip
Name: !Ref 'ServiceName'
Port: !Ref 'ContainerPort'
Protocol: HTTP
UnhealthyThresholdCount: 2
VpcId:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'VPCId']]
LoadBalancerRule:
Type: AWS::ElasticLoadBalancingV2::ListenerRule
Properties:
Actions:
- TargetGroupArn: !Ref 'TargetGroup'
Type: 'forward'
Conditions:
- Field: path-pattern
Values: [!Ref 'Path']
ListenerArn:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'PublicListener']]
Priority: 1
LogGroup:
Type: AWS::Logs::LogGroup
Properties:
LogGroupName: !Ref 'ServiceName'
RetentionInDays: 1
TaskDefinition:
Type: AWS::ECS::TaskDefinition
Properties:
Family: !Ref 'ServiceName'
Cpu: !Ref 'ContainerCpu'
Memory: !Ref 'ContainerMemory'
NetworkMode: awsvpc
RequiresCompatibilities:
- FARGATE
ExecutionRoleArn:
Fn::ImportValue:
!Join [':', [!Ref 'StackName', 'ECSTaskExecutionRole']]
ContainerDefinitions:
- Name: !Ref 'ServiceName'
Cpu: !Ref 'ContainerCpu'
Memory: !Ref 'ContainerMemory'
Image: !Ref 'ImageUrl'
PortMappings:
- ContainerPort: !Ref 'ContainerPort'
LogConfiguration:
LogDriver: 'awslogs'
Options:
awslogs-group: !Ref 'ServiceName'
awslogs-region: !Ref AWS::Region
awslogs-stream-prefix: !Ref 'ServiceName'

View File

@@ -0,0 +1,17 @@
# Turning off the AWS pager so that the CLI doesn't open an editor for each command result
export AWS_PAGER=""
IMAGE_URL=$1
aws cloudformation update-stack \
--stack-name reflectoring-ecs-zero-downtime-deployment-service \
--use-previous-template \
--parameters \
ParameterKey=StackName,ParameterValue=reflectoring-ecs-zero-downtime-deployment-network \
ParameterKey=ServiceName,ParameterValue=reflectoring-hello-world \
ParameterKey=ImageUrl,ParameterValue=$IMAGE_URL \
ParameterKey=ContainerPort,ParameterValue=8080 \
ParameterKey=HealthCheckPath,ParameterValue=/hello \
ParameterKey=HealthCheckIntervalSeconds,ParameterValue=90
aws cloudformation wait stack-update-complete --stack-name reflectoring-ecs-zero-downtime-deployment-service

View File

@@ -0,0 +1,7 @@
# Overview
![RDS in private subnet](rds-in-private-subnet.svg)
# Companion Blog Post
[The AWS Journey Part 3: Connecting a Spring Boot Application to an RDS Instance with CloudFormation](https://reflectoring.io/aws-cloudformation-rds/)

View File

@@ -0,0 +1,88 @@
AWSTemplateFormatVersion: '2010-09-09'
Description: A stack that creates an RDS instance and places it into two subnets
Parameters:
NetworkStackName:
Type: String
Description: The name of the networking stack that this stack will build upon.
DBInstanceClass:
Type: String
Description: The ID of the second subnet to place the RDS instance into.
Default: 'db.t2.micro'
DBName:
Type: String
Description: The name of the database that is created within the PostgreSQL instance.
DBUsername:
Type: String
Description: The master user name for the PostgreSQL instance.
Resources:
Secret:
Type: "AWS::SecretsManager::Secret"
Properties:
Name: !Ref 'DBUsername'
GenerateSecretString:
# This will generate a JSON object with the keys "username" and password.
SecretStringTemplate: !Join ['', ['{"username": "', !Ref 'DBUsername' ,'"}']]
GenerateStringKey: "password"
PasswordLength: 32
ExcludeCharacters: '"@/\'
DBSubnetGroup:
Type: AWS::RDS::DBSubnetGroup
Properties:
DBSubnetGroupDescription: Subnet group for the RDS instance
DBSubnetGroupName: DBSubnetGroup
SubnetIds:
- Fn::ImportValue:
!Join [':', [!Ref 'NetworkStackName', 'PrivateSubnetOne']]
- Fn::ImportValue:
!Join [':', [!Ref 'NetworkStackName', 'PrivateSubnetTwo']]
PostgresInstance:
Type: AWS::RDS::DBInstance
Properties:
AllocatedStorage: 20
AvailabilityZone:
Fn::Select:
- 0
- Fn::GetAZs: {Ref: 'AWS::Region'}
DBInstanceClass: !Ref 'DBInstanceClass'
DBName: !Ref 'DBName'
DBSubnetGroupName: !Ref 'DBSubnetGroup'
Engine: postgres
EngineVersion: 11.5
MasterUsername: !Ref 'DBUsername'
MasterUserPassword: !Join ['', ['{{resolve:secretsmanager:', !Ref Secret, ':SecretString:password}}' ]]
PubliclyAccessible: false
VPCSecurityGroups:
- Fn::ImportValue:
!Join [':', [!Ref 'NetworkStackName', 'DBSecurityGroupId']]
SecretRDSInstanceAttachment:
Type: "AWS::SecretsManager::SecretTargetAttachment"
Properties:
SecretId: !Ref Secret
TargetId: !Ref PostgresInstance
TargetType: AWS::RDS::DBInstance
Outputs:
EndpointAddress:
Description: Address of the RDS endpoint.
Value: !GetAtt 'PostgresInstance.Endpoint.Address'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'EndpointAddress' ] ]
EndpointPort:
Description: Port of the RDS endpoint.
Value: !GetAtt 'PostgresInstance.Endpoint.Port'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'EndpointPort' ] ]
DBName:
Description: The name of the database that is created within the PostgreSQL instance.
Value: !Ref DBName
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'DBName' ] ]
Secret:
Description: Reference to the secret containing the password to the database.
Value: !Ref 'Secret'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'Secret' ] ]

View File

@@ -0,0 +1,298 @@
AWSTemplateFormatVersion: '2010-09-09'
Description: A network stack for deploying containers in AWS ECS.
This stack creates a VPC with two public subnets and a loadbalancer to balance traffic between those subnets.
Derived from a template at https://github.com/nathanpeck/aws-cloudformation-fargate.
Resources:
VPC:
Type: AWS::EC2::VPC
Properties:
CidrBlock: '10.0.0.0/16'
PublicSubnetOne:
Type: AWS::EC2::Subnet
Properties:
AvailabilityZone:
Fn::Select:
- 0
- Fn::GetAZs: {Ref: 'AWS::Region'}
VpcId: !Ref 'VPC'
CidrBlock: '10.0.1.0/24'
MapPublicIpOnLaunch: true
PublicSubnetTwo:
Type: AWS::EC2::Subnet
Properties:
AvailabilityZone:
Fn::Select:
- 1
- Fn::GetAZs: {Ref: 'AWS::Region'}
VpcId: !Ref 'VPC'
CidrBlock: '10.0.2.0/24'
MapPublicIpOnLaunch: true
InternetGateway:
Type: AWS::EC2::InternetGateway
GatewayAttachement:
Type: AWS::EC2::VPCGatewayAttachment
Properties:
VpcId: !Ref 'VPC'
InternetGatewayId: !Ref 'InternetGateway'
PublicRouteTable:
Type: AWS::EC2::RouteTable
Properties:
VpcId: !Ref 'VPC'
PublicSubnetOneRouteTableAssociation:
Type: AWS::EC2::SubnetRouteTableAssociation
Properties:
SubnetId: !Ref PublicSubnetOne
RouteTableId: !Ref PublicRouteTable
PublicSubnetTwoRouteTableAssociation:
Type: AWS::EC2::SubnetRouteTableAssociation
Properties:
SubnetId: !Ref PublicSubnetTwo
RouteTableId: !Ref PublicRouteTable
PublicRoute:
Type: AWS::EC2::Route
DependsOn: GatewayAttachement
Properties:
RouteTableId: !Ref 'PublicRouteTable'
DestinationCidrBlock: '0.0.0.0/0'
GatewayId: !Ref 'InternetGateway'
PublicLoadBalancerSecurityGroup:
Type: AWS::EC2::SecurityGroup
Properties:
GroupDescription: Access to the public facing load balancer
VpcId: !Ref 'VPC'
SecurityGroupIngress:
# Allow access to ALB from anywhere on the internet
- CidrIp: 0.0.0.0/0
IpProtocol: -1
PublicLoadBalancer:
Type: AWS::ElasticLoadBalancingV2::LoadBalancer
Properties:
Scheme: internet-facing
Subnets:
# The load balancer is placed into the public subnets, so that traffic
# from the internet can reach the load balancer directly via the internet gateway
- !Ref PublicSubnetOne
- !Ref PublicSubnetTwo
SecurityGroups: [!Ref 'PublicLoadBalancerSecurityGroup']
DummyTargetGroupPublic:
Type: AWS::ElasticLoadBalancingV2::TargetGroup
Properties:
HealthCheckIntervalSeconds: 6
HealthCheckPath: /
HealthCheckProtocol: HTTP
HealthCheckTimeoutSeconds: 5
HealthyThresholdCount: 2
Name: "no-op"
Port: 80
Protocol: HTTP
UnhealthyThresholdCount: 2
VpcId: !Ref 'VPC'
PublicLoadBalancerListener:
Type: AWS::ElasticLoadBalancingV2::Listener
DependsOn:
- PublicLoadBalancer
Properties:
DefaultActions:
- TargetGroupArn: !Ref 'DummyTargetGroupPublic'
Type: 'forward'
LoadBalancerArn: !Ref 'PublicLoadBalancer'
Port: 80
Protocol: HTTP
ECSCluster:
Type: AWS::ECS::Cluster
ECSSecurityGroup:
Type: AWS::EC2::SecurityGroup
Properties:
GroupDescription: Access to the ECS containers
VpcId: !Ref 'VPC'
ECSSecurityGroupIngressFromPublicALB:
Type: AWS::EC2::SecurityGroupIngress
Properties:
Description: Ingress from the public ALB
GroupId: !Ref 'ECSSecurityGroup'
IpProtocol: -1
SourceSecurityGroupId: !Ref 'PublicLoadBalancerSecurityGroup'
ECSSecurityGroupIngressFromSelf:
Type: AWS::EC2::SecurityGroupIngress
Properties:
Description: Ingress from other containers in the same security group
GroupId: !Ref 'ECSSecurityGroup'
IpProtocol: -1
SourceSecurityGroupId: !Ref 'ECSSecurityGroup'
ECSRole:
Type: AWS::IAM::Role
Properties:
AssumeRolePolicyDocument:
Statement:
- Effect: Allow
Principal:
Service: [ecs.amazonaws.com]
Action: ['sts:AssumeRole']
Path: /
Policies:
- PolicyName: ecs-service
PolicyDocument:
Statement:
- Effect: Allow
Action:
# Rules which allow ECS to attach network interfaces to instances
# on your behalf in order for awsvpc networking mode to work right
- 'ec2:AttachNetworkInterface'
- 'ec2:CreateNetworkInterface'
- 'ec2:CreateNetworkInterfacePermission'
- 'ec2:DeleteNetworkInterface'
- 'ec2:DeleteNetworkInterfacePermission'
- 'ec2:Describe*'
- 'ec2:DetachNetworkInterface'
# Rules which allow ECS to update load balancers on your behalf
# with the information sabout how to send traffic to your containers
- 'elasticloadbalancing:DeregisterInstancesFromLoadBalancer'
- 'elasticloadbalancing:DeregisterTargets'
- 'elasticloadbalancing:Describe*'
- 'elasticloadbalancing:RegisterInstancesWithLoadBalancer'
- 'elasticloadbalancing:RegisterTargets'
Resource: '*'
ECSTaskExecutionRole:
Type: AWS::IAM::Role
Properties:
AssumeRolePolicyDocument:
Statement:
- Effect: Allow
Principal:
Service: [ecs-tasks.amazonaws.com]
Action: ['sts:AssumeRole']
Path: /
Policies:
- PolicyName: AmazonECSTaskExecutionRolePolicy
PolicyDocument:
Statement:
- Effect: Allow
Action:
# Allow the ECS Tasks to download images from ECR
- 'ecr:GetAuthorizationToken'
- 'ecr:BatchCheckLayerAvailability'
- 'ecr:GetDownloadUrlForLayer'
- 'ecr:BatchGetImage'
# Allow the ECS tasks to upload logs to CloudWatch
- 'logs:CreateLogStream'
- 'logs:PutLogEvents'
Resource: '*'
PrivateSubnetOne:
Type: AWS::EC2::Subnet
Properties:
AvailabilityZone:
Fn::Select:
- 0
- Fn::GetAZs: {Ref: 'AWS::Region'}
VpcId: !Ref 'VPC'
CidrBlock: '10.0.101.0/24'
MapPublicIpOnLaunch: false
PrivateSubnetTwo:
Type: AWS::EC2::Subnet
Properties:
AvailabilityZone:
Fn::Select:
- 1
- Fn::GetAZs: {Ref: 'AWS::Region'}
VpcId: !Ref 'VPC'
CidrBlock: '10.0.102.0/24'
MapPublicIpOnLaunch: false
DBSecurityGroup:
Type: AWS::EC2::SecurityGroup
Properties:
GroupDescription: Access to the RDS instance
VpcId: !Ref 'VPC'
DBSecurityGroupIngressFromECS:
Type: AWS::EC2::SecurityGroupIngress
Properties:
Description: Ingress from the ECS containers to the RDS instance
GroupId: !Ref 'DBSecurityGroup'
IpProtocol: -1
SourceSecurityGroupId: !Ref 'ECSSecurityGroup'
Outputs:
PrivateSubnetOne:
Description: Private subnet one
Value: !Ref 'PrivateSubnetOne'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PrivateSubnetOne' ] ]
PrivateSubnetTwo:
Description: Private subnet two
Value: !Ref 'PrivateSubnetTwo'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PrivateSubnetTwo' ] ]
DBSecurityGroupId:
Description: ID of the security group that an RDS instance can be placed into.
Value: !Ref 'DBSecurityGroup'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'DBSecurityGroupId' ] ]
ClusterName:
Description: The name of the ECS cluster
Value: !Ref 'ECSCluster'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ClusterName' ] ]
ExternalUrl:
Description: The url of the external load balancer
Value: !Join ['', ['http://', !GetAtt 'PublicLoadBalancer.DNSName']]
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ExternalUrl' ] ]
ECSRole:
Description: The ARN of the ECS role
Value: !GetAtt 'ECSRole.Arn'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ECSRole' ] ]
ECSTaskExecutionRole:
Description: The ARN of the ECS role
Value: !GetAtt 'ECSTaskExecutionRole.Arn'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ECSTaskExecutionRole' ] ]
PublicListener:
Description: The ARN of the public load balancer's Listener
Value: !Ref PublicLoadBalancerListener
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PublicListener' ] ]
VPCId:
Description: The ID of the VPC that this stack is deployed in
Value: !Ref 'VPC'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'VPCId' ] ]
PublicSubnetOne:
Description: Public subnet one
Value: !Ref 'PublicSubnetOne'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PublicSubnetOne' ] ]
PublicSubnetTwo:
Description: Public subnet two
Value: !Ref 'PublicSubnetTwo'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'PublicSubnetTwo' ] ]
ECSSecurityGroup:
Description: A security group used to allow ECS containers to receive traffic
Value: !Ref 'ECSSecurityGroup'
Export:
Name: !Join [ ':', [ !Ref 'AWS::StackName', 'ECSSecurityGroup' ] ]

View File

@@ -0,0 +1 @@
<mxfile modified="2020-05-11T21:18:00.281Z" host="app.diagrams.net" agent="5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.149 Safari/537.36" etag="d22WT4Cb11cg7E6o-Mdr" version="13.0.9" type="device"><diagram id="Ht1M8jgEwFfnCIfOTk4-" name="Page-1">7VvZcuI4FP0aHpuyJK+PYUk6VemaTNHTyxNlsGI8MRYtiy1fP5KRwZbEkkBI00OKqljXspZ7z7mLDA3UHi/uaDgZfSERThvQihYN1GlACJDj8H9CslxJPM9eCWKaRLLTRtBLXrAUWlI6TSKc1zoyQlKWTOrCIckyPGQ1WUgpmde7PZG0PuskjLEm6A3DVJd+TyI2klLgBpsbn3ESj+TUPvRWN8Zh2VnuJB+FEZlXRKjbQG1KCFtdjRdtnArllXpZPXe75e56YRRn7JAHHuJp6+UXX9i3PB/cv7TDr5/+/SRHmYXpVG74cTpIk6FY73SQYSbXzpalQiYkyVihVKfFP3zOttVw+J22aDWhowjUtlcXAL0lxqgL1LZXFwB1eKDMD9QFVgRaqza8pcxvVRbIP6hFpixNMtxew8/iwpiGUcLN0iYpoVyWkYxrrzVi45S3AL+cjxKGe5NwKLQ659ThsieSMUkAAMu2VLx4hgNoIq7Hi1hwrRnOc7sZUzKdFFPecwoY7/ZzPJzShC37m849RskzlsvNi0a52AZE0PZ9YIslJGlakXeDW9R1uXyGKUs4SW7SJBaTMiKGDWUrxU9MDMu3l2TxQ9HqIEtuyTRPFOYjHMnlSEjyKfBiK9bBmkHc9WAyxowueRf5AHIk6aTXQaU7mVc47EvZqEJf4IICIYX7kK4jXg+/YRe/kAQzk22Eh3Dxcu9977wMnl37S/SrP/hUeoIK2749tq8Mu3yGzSbDg3kkl3oiCt3ctLyWb6aQxhcDq7ZSCLh1CgFLp5BrGyiEAut4/hiDla0HK5rMQoav0eoP4tL/L1o5wQdHq0U6ve3jv2af7eXPX2zwzwu+m5pSwyvbrmz7Hdh2VGBT2QbgmdlmjG2OxrYO36zVk0Sz7grzqIQz5BWawZwbt+27VUWCrVZSYaXYZD2UYs0T+EAXKlZxDFYptV9LN8AJ0g1juo6utfHV//15/k+tjc/u/4xkA57Gtm67JzwgprOEQ+G3dn3HGcQ/wPUhU6X1bq5Pj0YN6KZivwN+EYuLm8mE+8KQJZxZ5T1a3nwgYaRLue7CbIhpeYcvbT2cZl+j86hxobTjQzjA6SPJk2ItqDMgjJHxXiYOucX4Wmqux+BGUDPc7LSf8o31B+U+NCdw6/gOsrd7uROgBdp1tEDXagKkl+aBjhcPvhNc/P1wuRfKLmKmG46FGbJBPik0oqLkjpcY83B5YSBJ5P76sVy+GRvuu2Jj7SU22PhYYARbnPrXMH8+zJhqVETwVsyvKVEo2PO7VpV8nYTygVb2zggVGlCN0rGcNg89htjxVPydAU77Upswn6zU8ZQsxDrMuQ7FOZnSIV5lOi3eNOU8eJifBmk2UGKWryPNM4Qs770iFtSzdQ1gOIpxqVkBBxKTLEy7G2nVLDiLbsT7Q2HclAyfhSgdFO3SxgVsQsrKfpLI/MnbJF17Cy0psZ2WK2DKE84sWiOL24Iuf1QbP0WD59ey2VlUb3aW1dYjpgnXo4DW7jRxBZJdepSU5fuKMdvv84VOdwKmmsSUR8gUpzyczuqvWE2QkMM9irpqAz6lgIeBq+Wlq33K56ovRZWhgFJ2Il/PcVeq0MYqYLre6BHIda/IPQC5ewHpfBwgoXVCRCrVAArOj0hTPndJiHw7iIKPAxGyAhVEb0OQXX7npkSQbTWtyh84CEzcECIJX3eTZ1vblw81DuxcpdYfOAqWVys4LbL1hHRXpXKRBQh8femx/mrS5sSr/LITOlHVqhYmgZ4uBk3D8a5jH58wGl9vwf1I4NZiMcW9vx94x/uM+6dMHERdFCxolOt4gF0PFV8aeL9S1LXtmsWBZ6/DWNXoUDe5v8N1HmXySy8Rtpplb1ZvSOp3keJDwh9Qwh+0m77/tgjoAnNsOXXMc3bHsNf2PzrmGd8s6qi/nsH8LmcwR70yVc9gkGs3TXH1nY5hjGC7+Fp2kbAf5dz8ulLJ8tamkBWNZaVhLmMVP/o23+3ovns7zz/EVSPrrZWK6g8PLHTPXZvY1hn8tP4C9MKoc/pjoNfyZ1f8Oyz3OQt/7KBekEOVBE0L2bYPPcd3oeW9MQdybGVYHh38wHUc4PHQgdR3PqdKidz6bhTq7O2/L4VS64ojUyje3PwCZ9V98zsm1P0P</diagram></mxfile>

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 32 KiB

View File

@@ -0,0 +1,164 @@
AWSTemplateFormatVersion: '2010-09-09'
Description: Deploy a service on AWS Fargate, hosted in two public subnets and accessible via a public load balancer.
Derived from a template at https://github.com/nathanpeck/aws-cloudformation-fargate.
Parameters:
NetworkStackName:
Type: String
Description: The name of the networking stack that
these resources are put into.
DatabaseStackName:
Type: String
Description: The name of the database stack with the database this service should connect to.
ServiceName:
Type: String
Description: A human-readable name for the service.
HealthCheckPath:
Type: String
Default: /health
Description: Path to perform the healthcheck on each instance.
HealthCheckIntervalSeconds:
Type: Number
Default: 5
Description: Number of seconds to wait between each health check.
ImageUrl:
Type: String
Description: The url of a docker image that will handle incoming traffic.
ContainerPort:
Type: Number
Default: 80
Description: The port number the application inside the docker container
is binding to.
ContainerCpu:
Type: Number
Default: 256
Description: How much CPU to give the container. 1024 is 1 CPU.
ContainerMemory:
Type: Number
Default: 512
Description: How much memory in megabytes to give the container.
Path:
Type: String
Default: "*"
Description: A path on the public load balancer that this service
should be connected to.
DesiredCount:
Type: Number
Default: 2
Description: How many copies of the service task to run.
Resources:
TargetGroup:
Type: AWS::ElasticLoadBalancingV2::TargetGroup
Properties:
HealthCheckIntervalSeconds: !Ref 'HealthCheckIntervalSeconds'
HealthCheckPath: !Ref 'HealthCheckPath'
HealthCheckProtocol: HTTP
HealthCheckTimeoutSeconds: 5
HealthyThresholdCount: 2
TargetType: ip
Name: !Ref 'ServiceName'
Port: !Ref 'ContainerPort'
Protocol: HTTP
UnhealthyThresholdCount: 2
VpcId:
Fn::ImportValue:
!Join [':', [!Ref 'NetworkStackName', 'VPCId']]
LoadBalancerRule:
Type: AWS::ElasticLoadBalancingV2::ListenerRule
Properties:
Actions:
- TargetGroupArn: !Ref 'TargetGroup'
Type: 'forward'
Conditions:
- Field: path-pattern
Values: [!Ref 'Path']
ListenerArn:
Fn::ImportValue:
!Join [':', [!Ref 'NetworkStackName', 'PublicListener']]
Priority: 1
LogGroup:
Type: AWS::Logs::LogGroup
Properties:
LogGroupName: !Ref 'ServiceName'
RetentionInDays: 1
TaskDefinition:
Type: AWS::ECS::TaskDefinition
Properties:
Family: !Ref 'ServiceName'
Cpu: !Ref 'ContainerCpu'
Memory: !Ref 'ContainerMemory'
NetworkMode: awsvpc
RequiresCompatibilities:
- FARGATE
ExecutionRoleArn:
Fn::ImportValue:
!Join [':', [!Ref 'NetworkStackName', 'ECSTaskExecutionRole']]
ContainerDefinitions:
- Name: !Ref 'ServiceName'
Cpu: !Ref 'ContainerCpu'
Memory: !Ref 'ContainerMemory'
Image: !Ref 'ImageUrl'
Environment:
- Name: SPRING_DATASOURCE_URL
Value: !Join
- ''
- - 'jdbc:postgresql://'
- Fn::ImportValue: !Join [':', [!Ref 'DatabaseStackName', 'EndpointAddress']]
- ':'
- Fn::ImportValue: !Join [':', [!Ref 'DatabaseStackName', 'EndpointPort']]
- '/'
- Fn::ImportValue: !Join [':', [!Ref 'DatabaseStackName', 'DBName']]
- Name: SPRING_DATASOURCE_USERNAME
Value: !Join
- ''
- - '{{resolve:secretsmanager:'
- Fn::ImportValue: !Join [':', [!Ref 'DatabaseStackName', 'Secret']]
- ':SecretString:username}}'
- Name: SPRING_DATASOURCE_PASSWORD
Value: !Join
- ''
- - '{{resolve:secretsmanager:'
- Fn::ImportValue: !Join [':', [!Ref 'DatabaseStackName', 'Secret']]
- ':SecretString:password}}'
PortMappings:
- ContainerPort: !Ref 'ContainerPort'
LogConfiguration:
LogDriver: 'awslogs'
Options:
awslogs-group: !Ref 'ServiceName'
awslogs-region: !Ref AWS::Region
awslogs-stream-prefix: !Ref 'ServiceName'
Service:
Type: AWS::ECS::Service
DependsOn: LoadBalancerRule
Properties:
ServiceName: !Ref 'ServiceName'
Cluster:
Fn::ImportValue:
!Join [':', [!Ref 'NetworkStackName', 'ClusterName']]
LaunchType: FARGATE
DeploymentConfiguration:
MaximumPercent: 200
MinimumHealthyPercent: 50
DesiredCount: !Ref 'DesiredCount'
NetworkConfiguration:
AwsvpcConfiguration:
AssignPublicIp: ENABLED
SecurityGroups:
- Fn::ImportValue:
!Join [':', [!Ref 'NetworkStackName', 'ECSSecurityGroup']]
Subnets:
- Fn::ImportValue:
!Join [':', [!Ref 'NetworkStackName', 'PublicSubnetOne']]
- Fn::ImportValue:
!Join [':', [!Ref 'NetworkStackName', 'PublicSubnetTwo']]
TaskDefinition: !Ref 'TaskDefinition'
LoadBalancers:
- ContainerName: !Ref 'ServiceName'
ContainerPort: !Ref 'ContainerPort'
TargetGroupArn: !Ref 'TargetGroup'

Binary file not shown.

View File

@@ -0,0 +1,18 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.6.3/apache-maven-3.6.3-bin.zip
wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar

8
aws/kinesis/README.md Normal file
View File

@@ -0,0 +1,8 @@
# Getting started with AWS Kinesis
Blog posts about this topic:
* [Getting started with AWS Kinesis](https://reflectoring.io/getting-started-with-aws-kinesis/)

316
aws/kinesis/mvnw vendored Executable file
View File

@@ -0,0 +1,316 @@
#!/bin/sh
# ----------------------------------------------------------------------------
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
# ----------------------------------------------------------------------------
# ----------------------------------------------------------------------------
# Maven Start Up Batch script
#
# Required ENV vars:
# ------------------
# JAVA_HOME - location of a JDK home dir
#
# Optional ENV vars
# -----------------
# M2_HOME - location of maven2's installed home dir
# MAVEN_OPTS - parameters passed to the Java VM when running Maven
# e.g. to debug Maven itself, use
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files
# ----------------------------------------------------------------------------
if [ -z "$MAVEN_SKIP_RC" ] ; then
if [ -f /usr/local/etc/mavenrc ] ; then
. /usr/local/etc/mavenrc
fi
if [ -f /etc/mavenrc ] ; then
. /etc/mavenrc
fi
if [ -f "$HOME/.mavenrc" ] ; then
. "$HOME/.mavenrc"
fi
fi
# OS specific support. $var _must_ be set to either true or false.
cygwin=false;
darwin=false;
mingw=false
case "`uname`" in
CYGWIN*) cygwin=true ;;
MINGW*) mingw=true;;
Darwin*) darwin=true
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html
if [ -z "$JAVA_HOME" ]; then
if [ -x "/usr/libexec/java_home" ]; then
export JAVA_HOME="`/usr/libexec/java_home`"
else
export JAVA_HOME="/Library/Java/Home"
fi
fi
;;
esac
if [ -z "$JAVA_HOME" ] ; then
if [ -r /etc/gentoo-release ] ; then
JAVA_HOME=`java-config --jre-home`
fi
fi
if [ -z "$M2_HOME" ] ; then
## resolve links - $0 may be a link to maven's home
PRG="$0"
# need this for relative symlinks
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG="`dirname "$PRG"`/$link"
fi
done
saveddir=`pwd`
M2_HOME=`dirname "$PRG"`/..
# make it fully qualified
M2_HOME=`cd "$M2_HOME" && pwd`
cd "$saveddir"
# echo Using m2 at $M2_HOME
fi
# For Cygwin, ensure paths are in UNIX format before anything is touched
if $cygwin ; then
[ -n "$M2_HOME" ] &&
M2_HOME=`cygpath --unix "$M2_HOME"`
[ -n "$JAVA_HOME" ] &&
JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
[ -n "$CLASSPATH" ] &&
CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
fi
# For Mingw, ensure paths are in UNIX format before anything is touched
if $mingw ; then
[ -n "$M2_HOME" ] &&
M2_HOME="`(cd "$M2_HOME"; pwd)`"
[ -n "$JAVA_HOME" ] &&
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
fi
if [ -z "$JAVA_HOME" ]; then
javaExecutable="`which javac`"
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
# readlink(1) is not available as standard on Solaris 10.
readLink=`which readlink`
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
if $darwin ; then
javaHome="`dirname \"$javaExecutable\"`"
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
else
javaExecutable="`readlink -f \"$javaExecutable\"`"
fi
javaHome="`dirname \"$javaExecutable\"`"
javaHome=`expr "$javaHome" : '\(.*\)/bin'`
JAVA_HOME="$javaHome"
export JAVA_HOME
fi
fi
fi
if [ -z "$JAVACMD" ] ; then
if [ -n "$JAVA_HOME" ] ; then
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
# IBM's JDK on AIX uses strange locations for the executables
JAVACMD="$JAVA_HOME/jre/sh/java"
else
JAVACMD="$JAVA_HOME/bin/java"
fi
else
JAVACMD="`\\unset -f command; \\command -v java`"
fi
fi
if [ ! -x "$JAVACMD" ] ; then
echo "Error: JAVA_HOME is not defined correctly." >&2
echo " We cannot execute $JAVACMD" >&2
exit 1
fi
if [ -z "$JAVA_HOME" ] ; then
echo "Warning: JAVA_HOME environment variable is not set."
fi
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
# traverses directory structure from process work directory to filesystem root
# first directory with .mvn subdirectory is considered project base directory
find_maven_basedir() {
if [ -z "$1" ]
then
echo "Path not specified to find_maven_basedir"
return 1
fi
basedir="$1"
wdir="$1"
while [ "$wdir" != '/' ] ; do
if [ -d "$wdir"/.mvn ] ; then
basedir=$wdir
break
fi
# workaround for JBEAP-8937 (on Solaris 10/Sparc)
if [ -d "${wdir}" ]; then
wdir=`cd "$wdir/.."; pwd`
fi
# end of workaround
done
echo "${basedir}"
}
# concatenates all lines of a file
concat_lines() {
if [ -f "$1" ]; then
echo "$(tr -s '\n' ' ' < "$1")"
fi
}
BASE_DIR=`find_maven_basedir "$(pwd)"`
if [ -z "$BASE_DIR" ]; then
exit 1;
fi
##########################################################################################
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
# This allows using the maven wrapper in projects that prohibit checking in binary data.
##########################################################################################
if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found .mvn/wrapper/maven-wrapper.jar"
fi
else
if [ "$MVNW_VERBOSE" = true ]; then
echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
fi
if [ -n "$MVNW_REPOURL" ]; then
jarUrl="$MVNW_REPOURL/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
else
jarUrl="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
fi
while IFS="=" read key value; do
case "$key" in (wrapperUrl) jarUrl="$value"; break ;;
esac
done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties"
if [ "$MVNW_VERBOSE" = true ]; then
echo "Downloading from: $jarUrl"
fi
wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar"
if $cygwin; then
wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"`
fi
if command -v wget > /dev/null; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found wget ... using wget"
fi
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
wget "$jarUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath"
else
wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath"
fi
elif command -v curl > /dev/null; then
if [ "$MVNW_VERBOSE" = true ]; then
echo "Found curl ... using curl"
fi
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
curl -o "$wrapperJarPath" "$jarUrl" -f
else
curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f
fi
else
if [ "$MVNW_VERBOSE" = true ]; then
echo "Falling back to using Java to download"
fi
javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java"
# For Cygwin, switch paths to Windows format before running javac
if $cygwin; then
javaClass=`cygpath --path --windows "$javaClass"`
fi
if [ -e "$javaClass" ]; then
if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
if [ "$MVNW_VERBOSE" = true ]; then
echo " - Compiling MavenWrapperDownloader.java ..."
fi
# Compiling the Java class
("$JAVA_HOME/bin/javac" "$javaClass")
fi
if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
# Running the downloader
if [ "$MVNW_VERBOSE" = true ]; then
echo " - Running MavenWrapperDownloader.java ..."
fi
("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR")
fi
fi
fi
fi
##########################################################################################
# End of extension
##########################################################################################
export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}
if [ "$MVNW_VERBOSE" = true ]; then
echo $MAVEN_PROJECTBASEDIR
fi
MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
# For Cygwin, switch paths to Windows format before running java
if $cygwin; then
[ -n "$M2_HOME" ] &&
M2_HOME=`cygpath --path --windows "$M2_HOME"`
[ -n "$JAVA_HOME" ] &&
JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
[ -n "$CLASSPATH" ] &&
CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
[ -n "$MAVEN_PROJECTBASEDIR" ] &&
MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"`
fi
# Provide a "standardized" way to retrieve the CLI args that will
# work with both Windows and non-Windows executions.
MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
export MAVEN_CMD_LINE_ARGS
WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
exec "$JAVACMD" \
$MAVEN_OPTS \
$MAVEN_DEBUG_OPTS \
-classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
"-Dmaven.home=${M2_HOME}" \
"-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"

188
aws/kinesis/mvnw.cmd vendored Normal file
View File

@@ -0,0 +1,188 @@
@REM ----------------------------------------------------------------------------
@REM Licensed to the Apache Software Foundation (ASF) under one
@REM or more contributor license agreements. See the NOTICE file
@REM distributed with this work for additional information
@REM regarding copyright ownership. The ASF licenses this file
@REM to you under the Apache License, Version 2.0 (the
@REM "License"); you may not use this file except in compliance
@REM with the License. You may obtain a copy of the License at
@REM
@REM http://www.apache.org/licenses/LICENSE-2.0
@REM
@REM Unless required by applicable law or agreed to in writing,
@REM software distributed under the License is distributed on an
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
@REM KIND, either express or implied. See the License for the
@REM specific language governing permissions and limitations
@REM under the License.
@REM ----------------------------------------------------------------------------
@REM ----------------------------------------------------------------------------
@REM Maven Start Up Batch script
@REM
@REM Required ENV vars:
@REM JAVA_HOME - location of a JDK home dir
@REM
@REM Optional ENV vars
@REM M2_HOME - location of maven2's installed home dir
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
@REM e.g. to debug Maven itself, use
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
@REM ----------------------------------------------------------------------------
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
@echo off
@REM set title of command window
title %0
@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO%
@REM set %HOME% to equivalent of $HOME
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
@REM Execute a user defined script before this one
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
@REM check for pre script, once with legacy .bat ending and once with .cmd ending
if exist "%USERPROFILE%\mavenrc_pre.bat" call "%USERPROFILE%\mavenrc_pre.bat" %*
if exist "%USERPROFILE%\mavenrc_pre.cmd" call "%USERPROFILE%\mavenrc_pre.cmd" %*
:skipRcPre
@setlocal
set ERROR_CODE=0
@REM To isolate internal variables from possible post scripts, we use another setlocal
@setlocal
@REM ==== START VALIDATION ====
if not "%JAVA_HOME%" == "" goto OkJHome
echo.
echo Error: JAVA_HOME not found in your environment. >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
:OkJHome
if exist "%JAVA_HOME%\bin\java.exe" goto init
echo.
echo Error: JAVA_HOME is set to an invalid directory. >&2
echo JAVA_HOME = "%JAVA_HOME%" >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
@REM ==== END VALIDATION ====
:init
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
@REM Fallback to current working directory if not found.
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
set EXEC_DIR=%CD%
set WDIR=%EXEC_DIR%
:findBaseDir
IF EXIST "%WDIR%"\.mvn goto baseDirFound
cd ..
IF "%WDIR%"=="%CD%" goto baseDirNotFound
set WDIR=%CD%
goto findBaseDir
:baseDirFound
set MAVEN_PROJECTBASEDIR=%WDIR%
cd "%EXEC_DIR%"
goto endDetectBaseDir
:baseDirNotFound
set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
cd "%EXEC_DIR%"
:endDetectBaseDir
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
@setlocal EnableExtensions EnableDelayedExpansion
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
:endReadAdditionalConfig
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B
)
@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
@REM This allows using the maven wrapper in projects that prohibit checking in binary data.
if exist %WRAPPER_JAR% (
if "%MVNW_VERBOSE%" == "true" (
echo Found %WRAPPER_JAR%
)
) else (
if not "%MVNW_REPOURL%" == "" (
SET DOWNLOAD_URL="%MVNW_REPOURL%/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
)
if "%MVNW_VERBOSE%" == "true" (
echo Couldn't find %WRAPPER_JAR%, downloading it ...
echo Downloading from: %DOWNLOAD_URL%
)
powershell -Command "&{"^
"$webclient = new-object System.Net.WebClient;"^
"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
"}"^
"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^
"}"
if "%MVNW_VERBOSE%" == "true" (
echo Finished downloading %WRAPPER_JAR%
)
)
@REM End of extension
@REM Provide a "standardized" way to retrieve the CLI args that will
@REM work with both Windows and non-Windows executions.
set MAVEN_CMD_LINE_ARGS=%*
%MAVEN_JAVA_EXE% ^
%JVM_CONFIG_MAVEN_PROPS% ^
%MAVEN_OPTS% ^
%MAVEN_DEBUG_OPTS% ^
-classpath %WRAPPER_JAR% ^
"-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" ^
%WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
if ERRORLEVEL 1 goto error
goto end
:error
set ERROR_CODE=1
:end
@endlocal & set ERROR_CODE=%ERROR_CODE%
if not "%MAVEN_SKIP_RC%"=="" goto skipRcPost
@REM check for post script, once with legacy .bat ending and once with .cmd ending
if exist "%USERPROFILE%\mavenrc_post.bat" call "%USERPROFILE%\mavenrc_post.bat"
if exist "%USERPROFILE%\mavenrc_post.cmd" call "%USERPROFILE%\mavenrc_post.cmd"
:skipRcPost
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
if "%MAVEN_BATCH_PAUSE%"=="on" pause
if "%MAVEN_TERMINATE_CMD%"=="on" exit %ERROR_CODE%
cmd /C exit /B %ERROR_CODE%

72
aws/kinesis/pom.xml Normal file
View File

@@ -0,0 +1,72 @@
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>io.pratik</groupId>
<artifactId>kinesisexamples</artifactId>
<version>0.0.1-SNAPSHOT</version>
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>software.amazon.awssdk</groupId>
<artifactId>kinesis</artifactId>
</dependency>
<!-- <dependency> <groupId>com.amazonaws</groupId> <artifactId>amazon-kinesis-producer</artifactId>
<version>0.14.10</version> </dependency> <dependency> <groupId>software.amazon.kinesis</groupId>
<artifactId>amazon-kinesis-client</artifactId> <version>2.3.10</version>
</dependency> -->
<dependency>
<groupId>software.amazon.awssdk</groupId>
<artifactId>firehose</artifactId>
</dependency>
<dependency>
<groupId>software.amazon.awssdk</groupId>
<artifactId>kinesisanalyticsv2</artifactId>
</dependency>
<dependency>
<groupId>software.amazon.awssdk</groupId>
<artifactId>kinesisvideo</artifactId>
</dependency>
<dependency>
<groupId>software.amazon.awssdk</groupId>
<artifactId>kinesisvideomedia</artifactId>
</dependency>
<dependency>
<groupId>com.amazonaws</groupId>
<artifactId>amazon-kinesis-video-streams-producer-sdk-java</artifactId>
<version>1.12.0</version>
</dependency>
<dependency>
<groupId>org.apache.flink</groupId>
<artifactId>flink-streaming-java_2.11</artifactId>
<version>1.14.3</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.apache.flink</groupId>
<artifactId>flink-clients_2.11</artifactId>
<version>1.14.3</version>
</dependency>
<dependency>
<groupId>software.amazon.kinesis</groupId>
<artifactId>amazon-kinesis-connector-flink</artifactId>
<version>2.3.0</version>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>software.amazon.awssdk</groupId>
<artifactId>bom</artifactId>
<version>2.17.116</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
</project>

View File

@@ -0,0 +1,16 @@
/**
*
*/
package io.pratik;
import software.amazon.awssdk.regions.Region;
/**
* @author pratikdas
*
*/
public interface Constants {
String MY_DATA_STREAM = "mydatastream";
String AWS_PROFILE_NAME = "tompoc";
Region AWS_REGION = Region.AP_SOUTHEAST_2;
}

View File

@@ -0,0 +1,79 @@
/**
*
*/
package io.pratik;
import software.amazon.awssdk.auth.credentials.AwsCredentialsProvider;
import software.amazon.awssdk.auth.credentials.ProfileCredentialsProvider;
import software.amazon.awssdk.regions.Region;
import software.amazon.awssdk.services.kinesis.KinesisClient;
import software.amazon.awssdk.services.kinesis.model.CreateStreamRequest;
import software.amazon.awssdk.services.kinesis.model.CreateStreamResponse;
import software.amazon.awssdk.services.kinesis.model.DescribeStreamSummaryRequest;
import software.amazon.awssdk.services.kinesis.model.DescribeStreamSummaryResponse;
import software.amazon.awssdk.services.kinesis.model.ResourceNotFoundException;
import software.amazon.awssdk.services.kinesis.model.StreamDescriptionSummary;
import software.amazon.awssdk.services.kinesis.model.StreamMode;
import software.amazon.awssdk.services.kinesis.model.StreamModeDetails;
import software.amazon.awssdk.services.kinesis.model.StreamStatus;
/**
* @author pratikdas
*
*/
public class DataStreamResourceHelper {
/**
* @param args
*/
public static void main(String[] args) {
createDataStream();
}
public static void createDataStream() {
KinesisClient kinesisClient = getKinesisClient();
CreateStreamRequest createStreamRequest = CreateStreamRequest.builder().streamName(Constants.MY_DATA_STREAM).streamModeDetails(StreamModeDetails.builder().streamMode(StreamMode.ON_DEMAND).build()).build();
CreateStreamResponse createStreamResponse = kinesisClient.createStream(createStreamRequest);
DescribeStreamSummaryRequest describeStreamSummaryRequest = DescribeStreamSummaryRequest.builder().streamName(Constants.MY_DATA_STREAM ).build();
DescribeStreamSummaryResponse describeStreamSummaryResponse = kinesisClient.describeStreamSummary(describeStreamSummaryRequest );
long startTime = System.currentTimeMillis();
long endTime = startTime + ( 10 * 60 * 1000 );
while ( System.currentTimeMillis() < endTime ) {
try {
Thread.sleep(20 * 1000);
}
catch ( Exception e ) {}
try {
StreamDescriptionSummary streamDescSumm = describeStreamSummaryResponse.streamDescriptionSummary();
if(streamDescSumm.streamStatus().equals(StreamStatus.ACTIVE)) break;
try {
Thread.sleep( 1000 );
}catch ( Exception e ) {}
}catch ( ResourceNotFoundException e ) {}
}
}
private static KinesisClient getKinesisClient() {
AwsCredentialsProvider credentialsProvider = ProfileCredentialsProvider.create(Constants.AWS_PROFILE_NAME);
KinesisClient kinesisClient = KinesisClient
.builder()
.credentialsProvider(credentialsProvider)
.region(Region.US_EAST_1).build();
return kinesisClient;
}
}

View File

@@ -0,0 +1,79 @@
/**
*
*/
package io.pratik;
import java.util.List;
import java.util.logging.Logger;
import software.amazon.awssdk.auth.credentials.AwsCredentialsProvider;
import software.amazon.awssdk.auth.credentials.ProfileCredentialsProvider;
import software.amazon.awssdk.regions.Region;
import software.amazon.awssdk.services.kinesis.KinesisClient;
import software.amazon.awssdk.services.kinesis.model.GetRecordsRequest;
import software.amazon.awssdk.services.kinesis.model.GetRecordsResponse;
import software.amazon.awssdk.services.kinesis.model.GetShardIteratorRequest;
import software.amazon.awssdk.services.kinesis.model.GetShardIteratorResponse;
import software.amazon.awssdk.services.kinesis.model.Record;
import software.amazon.awssdk.services.kinesis.model.ShardIteratorType;
/**
* @author pratikdas
*
*/
public class EventConsumer {
private static final Logger logger = Logger.getLogger(EventConsumer.class.getName());
/**
* @param args
*/
public static void main(String[] args) {
receiveEvents();
}
public static void receiveEventsWithKCL() {}
public static void receiveEvents() {
KinesisClient kinesisClient = getKinesisClient();
String shardId = "shardId-000000000001";
GetShardIteratorRequest getShardIteratorRequest = GetShardIteratorRequest.builder().streamName(Constants.MY_DATA_STREAM).shardId(shardId).shardIteratorType(ShardIteratorType.TRIM_HORIZON.name()).build();
GetShardIteratorResponse getShardIteratorResponse = kinesisClient.getShardIterator(getShardIteratorRequest );
String shardIterator = getShardIteratorResponse.shardIterator();
logger.info("shardIterator " + shardIterator);
while(shardIterator != null) {
GetRecordsRequest getRecordsRequest = GetRecordsRequest.builder().shardIterator(shardIterator).limit(5).build();
GetRecordsResponse getRecordsResponse = kinesisClient.getRecords(getRecordsRequest );
List<Record> records = getRecordsResponse.records();
logger.info("count "+records.size());
records.forEach(record->{
byte[] dataInBytes = record.data().asByteArray();
logger.info(new String(dataInBytes));
});
shardIterator = getRecordsResponse.nextShardIterator();
}
kinesisClient.close();
}
private static KinesisClient getKinesisClient() {
AwsCredentialsProvider credentialsProvider = ProfileCredentialsProvider.create(Constants.AWS_PROFILE_NAME);
KinesisClient kinesisClient = KinesisClient
.builder()
.credentialsProvider(credentialsProvider)
.region(Region.US_EAST_1)
.build();
return kinesisClient;
}
}

View File

@@ -0,0 +1,104 @@
/**
*
*/
package io.pratik;
import java.nio.ByteBuffer;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Logger;
import software.amazon.awssdk.auth.credentials.AwsCredentialsProvider;
import software.amazon.awssdk.auth.credentials.ProfileCredentialsProvider;
import software.amazon.awssdk.core.SdkBytes;
import software.amazon.awssdk.regions.Region;
import software.amazon.awssdk.services.kinesis.KinesisClient;
import software.amazon.awssdk.services.kinesis.model.PutRecordRequest;
import software.amazon.awssdk.services.kinesis.model.PutRecordResponse;
import software.amazon.awssdk.services.kinesis.model.PutRecordsRequest;
import software.amazon.awssdk.services.kinesis.model.PutRecordsRequestEntry;
import software.amazon.awssdk.services.kinesis.model.PutRecordsResponse;
/**
* @author pratikdas
*
*/
public class EventSender {
private static final Logger logger = Logger.getLogger(EventSender.class.getName());
/**
* @param args
*/
public static void main(String[] args) {
sendEvent();
}
public static void sendEvent() {
KinesisClient kinesisClient = getKinesisClient();
String partitionKey = String.format("partitionKey-%d", 1);
SdkBytes data = SdkBytes.fromByteBuffer(ByteBuffer.wrap("Test data".getBytes()));
PutRecordRequest putRecordRequest
= PutRecordRequest
.builder()
.streamName(Constants.MY_DATA_STREAM)
.partitionKey(partitionKey)
.data(data)
.build();
PutRecordResponse putRecordResult
= kinesisClient.putRecord(putRecordRequest);
logger.info("Put Result" + putRecordResult);
kinesisClient.close();
}
public static void sendEvents() {
KinesisClient kinesisClient = getKinesisClient();
String partitionKey = String.format("partitionKey-%d", 1);
List <PutRecordsRequestEntry> putRecordsRequestEntryList = new ArrayList<>();
for (int i = 0; i < 5; i++) {
SdkBytes data = SdkBytes
.fromByteBuffer(ByteBuffer.wrap(("Test event "+i).getBytes()));
PutRecordsRequestEntry putRecordsRequestEntry
= PutRecordsRequestEntry.builder()
.data(data)
.partitionKey(partitionKey)
.build();
putRecordsRequestEntryList.add(putRecordsRequestEntry);
}
PutRecordsRequest putRecordsRequest
= PutRecordsRequest
.builder()
.streamName(Constants.MY_DATA_STREAM)
.records(putRecordsRequestEntryList)
.build();
PutRecordsResponse putRecordsResult = kinesisClient
.putRecords(putRecordsRequest);
logger.info("Put Result" + putRecordsResult);
kinesisClient.close();
}
private static KinesisClient getKinesisClient() {
AwsCredentialsProvider credentialsProvider = ProfileCredentialsProvider.create(Constants.AWS_PROFILE_NAME);
KinesisClient kinesisClient = KinesisClient
.builder()
.credentialsProvider(credentialsProvider)
.region(Region.US_EAST_1).build();
return kinesisClient;
}
}

View File

@@ -0,0 +1,63 @@
/**
*
*/
package io.pratik;
import java.nio.ByteBuffer;
import java.util.logging.Logger;
import software.amazon.awssdk.auth.credentials.AwsCredentialsProvider;
import software.amazon.awssdk.auth.credentials.ProfileCredentialsProvider;
import software.amazon.awssdk.core.SdkBytes;
import software.amazon.awssdk.regions.Region;
import software.amazon.awssdk.services.firehose.FirehoseClient;
import software.amazon.awssdk.services.firehose.model.PutRecordRequest;
import software.amazon.awssdk.services.firehose.model.PutRecordResponse;
import software.amazon.awssdk.services.firehose.model.Record;
/**
* @author pratikdas
*
*/
public class FirehoseEventSender {
private final static Logger logger = Logger.getLogger(FirehoseEventSender.class.getName());
/**
* @param args
*/
public static void main(String[] args) {
new FirehoseEventSender().sendEvent();
}
public void sendEvent() {
String deliveryStreamName= "PUT-S3-5ZGgA";
String data = "Test data" + "\n";
;
Record record = Record.builder().data(SdkBytes.fromByteArray(data.getBytes())).build();
PutRecordRequest putRecordRequest = PutRecordRequest
.builder()
.deliveryStreamName(deliveryStreamName).record(record).build();
FirehoseClient firehoseClient = getFirehoseClient();
// Put record into the DeliveryStream
PutRecordResponse putRecordResponse = firehoseClient.putRecord(putRecordRequest);
logger.info("record ID:: " + putRecordResponse.recordId());
firehoseClient.close();
}
private static FirehoseClient getFirehoseClient() {
AwsCredentialsProvider credentialsProvider = ProfileCredentialsProvider.create(Constants.AWS_PROFILE_NAME);
FirehoseClient kinesisClient = FirehoseClient
.builder()
.credentialsProvider(credentialsProvider)
.region(Constants.AWS_REGION).build();
return kinesisClient;
}
}

View File

@@ -0,0 +1,84 @@
/**
*
*/
package io.pratik;
import software.amazon.awssdk.auth.credentials.AwsCredentialsProvider;
import software.amazon.awssdk.auth.credentials.ProfileCredentialsProvider;
import software.amazon.awssdk.regions.Region;
import software.amazon.awssdk.services.firehose.FirehoseClient;
import software.amazon.awssdk.services.firehose.model.CreateDeliveryStreamRequest;
import software.amazon.awssdk.services.firehose.model.CreateDeliveryStreamResponse;
import software.amazon.awssdk.services.firehose.model.DeliveryStreamType;
import software.amazon.awssdk.services.firehose.model.ExtendedS3DestinationConfiguration;
import software.amazon.awssdk.services.firehose.model.KinesisStreamSourceConfiguration;
import software.amazon.awssdk.services.firehose.model.S3DestinationConfiguration;
import software.amazon.awssdk.services.kinesis.KinesisClient;
import software.amazon.awssdk.services.kinesis.model.CreateStreamRequest;
import software.amazon.awssdk.services.kinesis.model.CreateStreamResponse;
import software.amazon.awssdk.services.kinesis.model.DescribeStreamSummaryRequest;
import software.amazon.awssdk.services.kinesis.model.DescribeStreamSummaryResponse;
import software.amazon.awssdk.services.kinesis.model.ResourceNotFoundException;
import software.amazon.awssdk.services.kinesis.model.StreamDescriptionSummary;
import software.amazon.awssdk.services.kinesis.model.StreamMode;
import software.amazon.awssdk.services.kinesis.model.StreamModeDetails;
import software.amazon.awssdk.services.kinesis.model.StreamStatus;
/**
* @author pratikdas
*
*/
public class FirehoseResourceHelper {
/**
* @param args
*/
public static void main(String[] args) {
createDeliveryStream();
}
public static void createDeliveryStream() {
FirehoseClient firehoseClient = getFirehoseClient();
String kinesisStreamARN = "";
String roleARN = "";
KinesisStreamSourceConfiguration kinesisStreamSourceConfiguration =
KinesisStreamSourceConfiguration.builder().build();
String bucketARN = "";
ExtendedS3DestinationConfiguration s3DestinationConfiguration
= ExtendedS3DestinationConfiguration.builder()
.bucketARN(bucketARN)
.build();
String streamName = "";
CreateDeliveryStreamRequest createDeliveryStreamRequest =
CreateDeliveryStreamRequest
.builder()
.deliveryStreamName(streamName )
.deliveryStreamType(DeliveryStreamType.DIRECT_PUT)
.kinesisStreamSourceConfiguration(kinesisStreamSourceConfiguration )
.extendedS3DestinationConfiguration(s3DestinationConfiguration )
.build();
CreateDeliveryStreamResponse response = firehoseClient.createDeliveryStream(createDeliveryStreamRequest );
firehoseClient.close();
}
private static FirehoseClient getFirehoseClient() {
AwsCredentialsProvider credentialsProvider =
ProfileCredentialsProvider.create(Constants.AWS_PROFILE_NAME);
FirehoseClient firehoseClient =
FirehoseClient.builder()
.credentialsProvider(credentialsProvider)
.region(Region.US_EAST_1)
.build();
return firehoseClient;
}
}

View File

@@ -0,0 +1,64 @@
/**
*
*/
package io.pratik;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.net.URL;
/**
* @author pratikdas
*
*/
public class StreamingDataGenerator {
/**
* @param args
*/
public static void main(String[] args) {
try {
new StreamingDataGenerator().generate();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
private void generate() throws Exception {
File file = getFile("apache_access_log");
// Note: Double backquote is to avoid compiler
// interpret words
// like \test as \t (ie. as a escape sequence)
// Creating an object of BufferedReader class
BufferedReader br
= new BufferedReader(new FileReader(file));
// Declaring a string variable
String st;
// Condition holds true till
// there is character in a string
while ((st = br.readLine()) != null) {
System.out.println(st);
break;
}
}
private File getFile(String fileName) throws IOException
{
ClassLoader classLoader = getClass().getClassLoader();
URL resource = classLoader.getResource(fileName);
if (resource == null) {
throw new IllegalArgumentException("file is not found!");
} else {
return new File(resource.getFile());
}
}
}

View File

@@ -0,0 +1,153 @@
package io.pratik.flink;
import java.io.File;
import java.io.IOException;
import java.net.URL;
import java.util.Properties;
import java.util.logging.Logger;
import org.apache.flink.api.common.functions.FilterFunction;
import org.apache.flink.api.common.functions.FlatMapFunction;
import org.apache.flink.api.common.serialization.SimpleStringSchema;
import org.apache.flink.streaming.api.datastream.DataStream;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.util.Collector;
import io.pratik.Constants;
import io.pratik.models.LogRecord;
import software.amazon.kinesis.connectors.flink.FlinkKinesisProducer;
import software.amazon.kinesis.connectors.flink.config.ConsumerConfigConstants;
public class ErrorCounter {
private final static Logger logger = Logger.getLogger(ErrorCounter.class.getName());
private static final String FILE_PATH = "/Users/pratikdas/eclipse-workspace/kinesisexamples/src/main/resources/apache_access_log";
public static void main(String[] args) throws Exception {
// set up the streaming execution environment
final StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
DataStream<String> inputStream = createSource(env);
DataStream<LogRecord> logRecords = mapStringToLogRecord(inputStream);
DataStream<LogRecord> errorRecords = filterErrorRecords(logRecords);
DataStream<LogRecord> keyedStream = assignIPasKey(errorRecords);
DataStream<String> keyedStreamAsText = mapLogRecordToString(keyedStream);
//TODO Uncomment this code for deploying to Kinesis Data Analytics
// keyedStream.addSink(createSink());
keyedStreamAsText.print();
env.execute("Error alerts");
}
private static DataStream<String> mapLogRecordToString(DataStream<LogRecord> keyedStream) {
DataStream<String> keyedStreamAsText = keyedStream.flatMap(new FlatMapFunction<LogRecord, String>() {
@Override
public void flatMap(LogRecord value, Collector<String> out) throws Exception {
out.collect(value.getUrl()+"::" + value.getHttpStatus());
}
});
return keyedStreamAsText;
}
private static DataStream<LogRecord> assignIPasKey(DataStream<LogRecord> errorRecords) {
DataStream<LogRecord> keyedStream = errorRecords.keyBy(value -> value.getIp());
return keyedStream;
}
private static DataStream<LogRecord> filterErrorRecords(DataStream<LogRecord> logRecords) {
DataStream<LogRecord> errorRecords = logRecords.filter(new FilterFunction<LogRecord>() {
@Override
public boolean filter(LogRecord value) throws Exception {
boolean matched = !value.getHttpStatus().equalsIgnoreCase("200");
return matched;
}
});
return errorRecords;
}
private static DataStream<LogRecord> mapStringToLogRecord(DataStream<String> inputStream) {
DataStream<LogRecord> logRecords = inputStream.flatMap(new FlatMapFunction<String, LogRecord>() {
@Override
public void flatMap(String value, Collector<LogRecord> out) throws Exception {
String[] parts = value.split("\\s+");
LogRecord record = new LogRecord();
record.setIp(parts[0]);
record.setHttpStatus(parts[8]);
record.setUrl(parts[6]);
out.collect(record);
}
});
return logRecords;
}
/*private static void createSink(final StreamExecutionEnvironment env, DataStream<LogRecord> input) {
input.print();
}*/
private static DataStream<String> createSource(final StreamExecutionEnvironment env) {
return env.readTextFile(
FILE_PATH);
}
//TODO Uncomment this code for deploying to Kinesis Data Analytics
/*private static DataStream<String> createSource(final StreamExecutionEnvironment env) {
Properties inputProperties = new Properties();
inputProperties.setProperty(ConsumerConfigConstants.AWS_REGION, Constants.AWS_REGION.toString());
inputProperties.setProperty(ConsumerConfigConstants.STREAM_INITIAL_POSITION, "LATEST");
String inputStreamName = "in-app-log-stream";
return env.addSource(new FlinkKinesisConsumer<>(inputStreamName, new SimpleStringSchema(), inputProperties));
}*/
private static FlinkKinesisProducer<String> createSink() {
Properties outputProperties = new Properties();
outputProperties.setProperty(ConsumerConfigConstants.AWS_REGION, Constants.AWS_REGION.toString());
FlinkKinesisProducer<String> sink = new FlinkKinesisProducer<>(new SimpleStringSchema(), outputProperties);
String outputStreamName = "log_data_stream";
sink.setDefaultStream(outputStreamName);
sink.setDefaultPartition("0");
return sink;
}
private File getFile(String fileName) throws IOException {
ClassLoader classLoader = getClass().getClassLoader();
URL resource = classLoader.getResource(fileName);
if (resource == null) {
throw new IllegalArgumentException("file is not found!");
} else {
return new File(resource.getFile());
}
}
}

View File

@@ -0,0 +1,40 @@
/**
*
*/
package io.pratik.models;
/**
* @author pratikdas
*
*/
public class LogRecord {
private String ip;
private String httpStatus;
private String url;
public String getIp() {
return ip;
}
public void setIp(String ip) {
this.ip = ip;
}
public String getHttpStatus() {
return httpStatus;
}
public void setHttpStatus(String httpStatus) {
this.httpStatus = httpStatus;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
@Override
public String toString() {
return "LogRecord [ip=" + ip + ", httpStatus=" + httpStatus + ", url=" + url + "]";
}
}

View File

@@ -0,0 +1,33 @@
83.149.9.216 - - [17/May/2015:10:05:03 +0000] "GET /presentations/logstash-monitorama-2013/images/kibana-search.png HTTP/1.1" 200 203023 "http://semicomplete.com/presentations/logstash-monitorama-2013/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.77 Safari/537.36"
83.149.9.216 - - [17/May/2015:10:05:43 +0000] "GET /presentations/logstash-monitorama-2013/images/kibana-dashboard3.png HTTP/1.1" 200 171717 "http://semicomplete.com/presentations/logstash-monitorama-2013/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.77 Safari/537.36"
83.149.9.216 - - [17/May/2015:10:05:47 +0000] "GET /presentations/logstash-monitorama-2013/plugin/highlight/highlight.js HTTP/1.1" 200 26185 "http://semicomplete.com/presentations/logstash-monitorama-2013/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.77 Safari/537.36"
83.149.9.216 - - [17/May/2015:10:05:12 +0000] "GET /presentations/logstash-monitorama-2013/plugin/zoom-js/zoom.js HTTP/1.1" 200 7697 "http://semicomplete.com/presentations/logstash-monitorama-2013/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.77 Safari/537.36"
83.149.9.216 - - [17/May/2015:10:05:07 +0000] "GET /presentations/logstash-monitorama-2013/plugin/notes/notes.js HTTP/1.1" 200 2892 "http://semicomplete.com/presentations/logstash-monitorama-2013/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.77 Safari/537.36"
83.149.9.216 - - [17/May/2015:10:05:34 +0000] "GET /presentations/logstash-monitorama-2013/images/sad-medic.png HTTP/1.1" 200 430406 "http://semicomplete.com/presentations/logstash-monitorama-2013/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.77 Safari/537.36"
83.149.9.216 - - [17/May/2015:10:05:57 +0000] "GET /presentations/logstash-monitorama-2013/css/fonts/Roboto-Bold.ttf HTTP/1.1" 404 38720 "http://semicomplete.com/presentations/logstash-monitorama-2013/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.77 Safari/537.36"
83.149.9.216 - - [17/May/2015:10:05:50 +0000] "GET /presentations/logstash-monitorama-2013/css/fonts/Roboto-Regular.ttf HTTP/1.1" 200 41820 "http://semicomplete.com/presentations/logstash-monitorama-2013/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.77 Safari/537.36"
83.149.9.216 - - [17/May/2015:10:05:24 +0000] "GET /presentations/logstash-monitorama-2013/images/frontend-response-codes.png HTTP/1.1" 310 52878 "http://semicomplete.com/presentations/logstash-monitorama-2013/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.77 Safari/537.36"
46.105.14.53 - - [17/May/2015:10:05:44 +0000] "GET /blog/tags/puppet?flav=rss20 HTTP/1.1" 200 14872 "-" "UniversalFeedParser/4.2-pre-314-svn +http://feedparser.org/"
20.241.23.22 - - [17/May/2015:10:05:47 +0000] "GET /blog/geekery/soekris-gpio.html HTTP/1.0" 200 9587 "http://www.semicomplete.com/blog/tags/C" "Mozilla/5.0 (compatible; archive.org_bot +http://www.archive.org/details/archive.org_bot)"
91.177.205.119 - - [17/May/2015:10:05:22 +0000] "GET /blog/geekery/xvfb-firefox.html HTTP/1.1" 200 10975 "http://en.wikipedia.org/wiki/Xvfb" "Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)"
91.177.205.119 - - [17/May/2015:10:05:34 +0000] "GET /reset.css HTTP/1.1" 200 1015 "http://semicomplete.com/blog/geekery/xvfb-firefox.html" "Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)"
91.177.205.119 - - [17/May/2015:10:05:37 +0000] "GET /style2.css HTTP/1.1" 200 4877 "http://semicomplete.com/blog/geekery/xvfb-firefox.html" "Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)"
91.177.205.119 - - [17/May/2015:10:05:54 +0000] "GET /images/jordan-80.png HTTP/1.1" 200 6146 "http://semicomplete.com/blog/geekery/xvfb-firefox.html" "Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)"
91.177.205.119 - - [17/May/2015:10:05:31 +0000] "GET /images/web/2009/banner.png HTTP/1.1" 200 52315 "http://semicomplete.com/blog/geekery/xvfb-firefox.html" "Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)"
91.177.205.119 - - [17/May/2015:10:05:32 +0000] "GET /favicon.ico HTTP/1.1" 200 3638 "-" "Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; Win64; x64; Trident/6.0)"
66.249.73.185 - - [17/May/2015:10:05:22 +0000] "GET /doc/index.html?org/elasticsearch/action/search/SearchResponse.html HTTP/1.1" 404 294 "-" "Mozilla/5.0 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)"
207.241.237.228 - - [17/May/2015:10:05:40 +0000] "GET /blog/tags/defcon HTTP/1.0" 200 24142 "http://www.semicomplete.com/blog/tags/C" "Mozilla/5.0 (compatible; archive.org_bot +http://www.archive.org/details/archive.org_bot)"
207.241.237.101 - - [17/May/2015:10:05:51 +0000] "GET /blog/tags/regex HTTP/1.0" 200 14888 "http://www.semicomplete.com/blog/tags/C" "Mozilla/5.0 (compatible; archive.org_bot +http://www.archive.org/details/archive.org_bot)"
87.169.99.232 - - [17/May/2015:10:05:59 +0000] "GET /presentations/puppet-at-loggly/puppet-at-loggly.pdf.html HTTP/1.1" 200 24747 "https://www.google.de/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.107 Safari/537.36"
209.85.238.199 - - [17/May/2015:10:05:30 +0000] "GET /blog/tags/firefox?flav=rss20 HTTP/1.1" 200 16021 "-" "Feedfetcher-Google; (+http://www.google.com/feedfetcher.html; 3 subscribers; feed-id=14171215010336145331)"
209.85.238.199 - - [17/May/2015:10:05:15 +0000] "GET /test.xml HTTP/1.1" 200 1370 "-" "Feedfetcher-Google; (+http://www.google.com/feedfetcher.html; 1 subscribers; feed-id=11390274670024826467)"
81.220.24.207 - - [17/May/2015:10:05:13 +0000] "GET /blog/geekery/ssl-latency.html HTTP/1.1" 200 17147 "http://www.google.fr/url?sa=t&rct=j&q=&esrc=s&source=web&cd=5&ved=0CE4QFjAE&url=http%3A%2F%2Fwww.semicomplete.com%2Fblog%2Fgeekery%2Fssl-latency.html&ei=ZdEAU9mGGuWX1AW09IDoBw&usg=AFQjCNHw6zioJpizqX8Q0YpKKaF4zdCSEg&bvm=bv.61535280,d.d2k" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.73.11 (KHTML, like Gecko) Version/7.0.1 Safari/537.73.11"
81.220.24.207 - - [17/May/2015:10:05:44 +0000] "GET /reset.css HTTP/1.1" 200 1015 "http://www.semicomplete.com/blog/geekery/ssl-latency.html" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.73.11 (KHTML, like Gecko) Version/7.0.1 Safari/537.73.11"
81.220.24.207 - - [17/May/2015:10:05:26 +0000] "GET /images/jordan-80.png HTTP/1.1" 200 6146 "http://www.semicomplete.com/blog/geekery/ssl-latency.html" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.73.11 (KHTML, like Gecko) Version/7.0.1 Safari/537.73.11"
81.220.24.207 - - [17/May/2015:10:05:39 +0000] "GET /style2.css HTTP/1.1" 200 4877 "http://www.semicomplete.com/blog/geekery/ssl-latency.html" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.73.11 (KHTML, like Gecko) Version/7.0.1 Safari/537.73.11"
81.220.24.207 - - [17/May/2015:10:05:52 +0000] "GET /images/web/2009/banner.png HTTP/1.1" 200 52315 "http://www.semicomplete.com/blog/geekery/ssl-latency.html" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.73.11 (KHTML, like Gecko) Version/7.0.1 Safari/537.73.11"
81.220.24.207 - - [17/May/2015:10:05:21 +0000] "GET /favicon.ico HTTP/1.1" 200 3638 "http://www.semicomplete.com/blog/geekery/ssl-latency.html" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.73.11 (KHTML, like Gecko) Version/7.0.1 Safari/537.73.11"
66.249.73.135 - - [17/May/2015:11:05:17 +0000] "GET /blog/geekery/vmware-cpu-performance.html HTTP/1.1" 200 12908 "-" "Mozilla/5.0 (iPhone; CPU iPhone OS 6_0 like Mac OS X) AppleWebKit/536.26 (KHTML, like Gecko) Version/6.0 Mobile/10A5376e Safari/8536.25 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)"
46.105.14.53 - - [17/May/2015:11:05:42 +0000] "GET /blog/tags/puppet?flav=rss20 HTTP/1.1" 200 14872 "-" "UniversalFeedParser/4.2-pre-314-svn +http://feedparser.org/"
218.30.103.62 - - [17/May/2015:11:05:11 +0000] "GET /robots.txt HTTP/1.1" 200 - "-" "Sogou web spider/4.0(+http://www.sogou.com/docs/help/webmasters.htm#07)"
218.30.103.62 - - [17/May/2015:11:05:46 +0000] "GET /robots.txt HTTP/1.1" 200 - "-" "Sogou web spider/4.0(+http://www.sogou.com/docs/help/webmasters.htm#07)"

View File

@@ -0,0 +1,33 @@
console.log('Loading function');
const validateRecord = (recordElement)=>{
// record is considered valid if contains status field
return recordElement.includes("status")
}
exports.handler = async (event, context) => {
/* Process the list of records and transform them */
const output = event.records.map((record)=>{
const decodedData = Buffer.from(record.data, "base64").toString("utf-8")
let isValidRecord = validateRecord(decodedData)
if(isValidRecord){
let parsedRecord = JSON.parse(decodedData)
// read fields from parsed JSON for some more processing
const outputRecord = `status::${parsedRecord.status}`
return {
recordId: record.recordId,
result: 'Ok',
// payload is encoded back to base64 before returning the result
data: Buffer.from(outputRecord, "utf-8").toString("base64")
}
}else{
return {
recordId: record.recordId,
result: 'dropped',
data: record.data // payload is kept intact,
}
}
})
};

Some files were not shown because too many files have changed in this diff Show More