-
Notifications
You must be signed in to change notification settings - Fork 615
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add Spring Cloud Stream version as part of message headers produced #2814
Comments
@sobychacko If the issue is available, I would like to try to solve it. Let me give you brief information on how to do it. Using the spring boot maven plugin, I will create the build-info.properties file under the META-INF directory at build time. Then I will inject this resource as a bean. And before sending the data, I will add it to the header. If you don't like the solution, I can think of another solution. |
@omercelikceng You can certainly work on the issue if you have the bandwidth. I am not sure if we want to use the boot maven plugin that way at build time in the framework. Usually, we don't include the boot maven plugin as part of the framework build, but is used by the applications to create a boot app. We don't want to accidentally create uber-jars from the framework. We probably can get this information differently and attach that to the jar manifest. |
@sobychacko OK, I'll think of another way. But I didn't understand what you mean in the following sentence.(Word I don't understand: bandwidth) Did you mean to ask if I've worked on this topic before?
|
I meant, if you have the time, go ahead and work on the issue:-) |
Ok thank you very much. Sorry for my bad English knowledge. :) I still need to learn some words. Please excuse me. I will work on this issue and write you my opinion. |
No worries. Please let us know if you have any questions on this issue. |
@sobychacko Hello. While the project is being built, I save the relevant Spring Cloud Stream version in the Manifest.mf file. My code works successfully in the following cases. But it is necessary to consider the following situations in detail. However, special situations may occur here. This pom.properties file may not be created depending on how the developer builds. Or should I give the developer a message like the one below and ignore the situations I explained? "No manifest file or pom.properties file found in the jar. Please review the build method." |
@omercelikceng Sorry for the delay in replying to you. I see that this is not a trivial problem to solve. I wonder if there is a more straightforward way to address this rather than going with the manifest route. We will explore if there is a solution and get back to you. In the meantime, please let us know if you can think of a better solution. |
@sobychacko.. No problem. I researched and found another solution. I can generate a class containing the version using the maven-antrun-plugin at compile time. What do you think about this solution? However, in this solution, the compile time of spring-cloud-stream will increase slightly. |
@omercelikceng That might not be a bad idea. How intrusive is the code for doing that? I want to keep the changes for this very minimal. @artembilan and I have briefly discussed this issue today, and he was also thinking about something along these lines, i.e., coming up with a static properties file with the version. |
We can get this info by parsing the JAR file name. We control it and we know that version is always going to be part of it.
|
See also It is probably may fail in case of shading, however in this case we may just fall back and don't provide such a |
Hello @olegz. Thank you very much for your interest. Actually, I developed my code as you said. But when I do it this way, the problems I mentioned above occur when it is a shaded jar. Problems: |
Hello @artembilan. Thank you very much for your interest. I couldn't fully understand some of what you wrote. Please excuse me if I have rewritten what you already wanted to say. Just wanted to check. I can do it this way. But when I generate shaded jar, the version is not null, we get the version of the main project. So I can't get the version of spring cloud stream. In this case, I need to check to understand that the value I got is the wrong version(main project version). I can do this like this(implementationTitle = "spring-cloud-stream"). But I'm not sure if this is a reliable way. But I can do whatever you say. Could you please check me? I will get the version as in the org.springframework.core.SpringVersion method. If I cannot get the version(shaded-jar), I will not publish the version information in the header. Should I implement the implementation this way? We gave up on implementing it this way, right?(#2814 (comment)) |
I see that They have a Gradle task for that template: https://github.com/spring-projects/spring-boot/blob/main/spring-boot-project/spring-boot/build.gradle#L153-L159 So, you might be not wrong going with something what could be done from Maven to modify such a template on project build. However the final solution is up to @olegz as he is a lead of the project. |
@artembilan You gave this example (org.springframework.core.SpringVersion). #2814 (comment) |
We are still gathering ideas how to implement this feature. |
Developers may not be able to use uber jar due to problems with the third party libraries they use. I currently have an example like this in my project.(If you want, I can explain the example in my project.) I'm trying to have a code that works in every case. But the final decision is yours, of course. |
This works in every case as shown earlier
|
Hello @olegz. I tried again. But what you said doesn't work in shaded jar. Because in shaded jar, all jars are extracted. And it is not available as spring cloud stream jar. If you want, I can share a poc showing that this doesn't work in shaded jar. Or I can ignore this situation and develop it as you say. |
You can also try to explore reading it from the MANIFEST
However not sure what manifest you'll see once the whole thing is shaded, but give it a shot and see what's in the manifest. We have plenty of samples how to read one from a zipped file Other then that, let me think a bit about it |
Ok. I wrote about the problems that occur when shaded jar occurs here(#2814 (comment)). As you said, the problems that occur when I try to read from the manifest file are listed here. That's why I offered to generate classes. (#2814 (comment)) But @artembilan also thinks like this. (#2814 (comment)) I couldn't decide what I should do last. I need your guidance. |
Well So we can either state that we would not support this feature if shaded or we can consider some type of Maven plugin/extension that would generate a class on evert build that we would reference to get the version. I'd be interested to see what it would look like. In other words we are back to your original proposal, so give it a shot |
I agree with what @olegz said, we only need to support this feature when using the boot plugin and won't support shade or other plugins. |
Hello, I haven't had time for the project for a long time. We are in a busy period at my company. I won't be able to spare time for this issue for a while.(maybe a month) Would there be any problems for you? |
@omercelikceng No worries. Let us know when you are able to pick this up again. Otherwise, we can take a look from our side. |
Hello, I am sorry. I've been working really hard for a while now. That's why I couldn't spare much time. But I have completed my development. However, we need to resolve this issue(#2983) before I can create the pull request because the changes I will make will also affect this part. Therefore, I cannot create the pull request. However, I wanted to let you know that I have completed the development. |
@omercelikceng given that #2983 is resolved would you like to finish this? |
Hello @olegz. I completed my development three months ago, but I have been very busy for a while now. I believe it would be more appropriate to tackle these header-related problems first. If you permit, I would like to resolve the other issues related to the headers before proceeding. After that, I would like to submit a pull request for this development. I also noticed and resolved the issue mentioned in #2869. However, I would like to request 1-2 months of time to complete everything and submit a comprehensive pull request. |
Adding the Spring Cloud Stream version as part of the message header is convenient for easier debugging of issues.
The text was updated successfully, but these errors were encountered: