-
-
Notifications
You must be signed in to change notification settings - Fork 27
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
Persistence schema modifications don't seem to update existing database #15
Comments
Thanks for reporting. The database should be migrated with the newest changes. You should be able to do this by running |
Hi @DavidLazarescu, Thanks for your advice mate. I have reverted my manual column creation to test, though it appears the docker image builds without containing a file path named "src/Presentation", however I assume this is meant to be the path from this repository. I attempted to run "dotnet ef upgrade" from a few seemingly likely locations in the default docker container without success: librum-server@librum:/var/lib/librum-server$ dotnet ef upgrade
The command could not be loaded, possibly because:
* You intended to execute a .NET application:
The application 'ef' does not exist.
* You intended to execute a .NET SDK command:
No .NET SDKs were found. I then installed the SDK and cloned the repo into the docker container. Within the container I built the application using the SDK using the selfhosting instructions, and changed into the src/Presentation dir. I then tried using both the dotnet runtime (docker container default) and dotnet sdk dotnet binaries to run "ef upgrade", but I am told there is no application named "ef" or "dotnet-ef", depending upon whether I tried sdk or runtime dotnet binaries, similar to the error above. I also tried this in the default workdir of the docker container entrypoint (basically the contents of src/Presentation/build), with similar results. I know nothing about dotnet, so I am unsure what the issue is, apologies if I'm just trying the wrong thing. |
In order to use the @DavidLazarescu This is can be risky, but perhaps in "production" mode (env check) you could automatically have EF apply the migrations on startup? |
It might be reasonable to do so in self-hosted environments. |
Can you confirm that the issue is fixed when you apply the migrations manually (running |
I have performed a clean installation of Librum on a kubernetes cluster and the application has started but it has only created the AspNetRoles and AspNetUsers tables (and has seeded them with the two roles and built-in user). |
This seems to be related to the fact that the migrations were generated using MSSQL and for self hosted you're using MySQL which has different data types and the CF migrations need to be regenerated. Additionally I've had to manually add a Product to login as it seems that it blows up beautifully otherwise. Seeding the admin user should have taken care of this. |
@paulcsiki thanks for the link to your post. I am trying to install librum with docker and it seems the issue reported above has not yet been solved. I am not technical and understand only vaguely what you did (changing the DB column types to text). |
Try this patch, don’t forget to create a product record in the db. |
Howdy,
I note ColorTheme is added here, and causes an unknown column error in my Librum server that existed before this change:
I suspect that this change should also exist in this file as it seems to be the primary schema definition (judging by the name, I know nothing at all about the framework at hand).
However I don't know if this would fix the issue. Is there currently a method of updating the database when starting a new version of the server? I manually created this column and all is now well.
Apologies if I shouldn't just be building out of the main branch or something. I couldn't see any already existing things that obviously address this issue.
The text was updated successfully, but these errors were encountered: