7
respostas

Erro ao subir aplicação java (java -jar java -jar cdcreact-1.0.0-SNAPSHOT.jar)

Ao executar o comando java -jar cdcreact-1.0.0-SNAPSHOT.jar, estou recebendo o erro abaixo:

java.lang.reflect.InvocationTargetException at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:53) at java.lang.Thread.run(Thread.java:748) Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaAutoConfiguration.class]: Invocation of init method failed; nested exception is org.hibernate.HibernateException: Access to DialectResolutionInfo cannot be null when 'hibernate.dialect' not set at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1578) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:545) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:482) at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306) at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302) at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197) at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1054) at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:829) at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:538) at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:118) at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:764) at org.springframework.boot.SpringApplication.doRun(SpringApplication.java:357) at org.springframework.boot.SpringApplication.run(SpringApplication.java:305) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1124) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1113) at br.com.caelum.cdcreact.Boot.main(Boot.java:10) ... 6 more Caused by: org.hibernate.HibernateException: Access to DialectResolutionInfo cannot be null when 'hibernate.dialect' not set at org.hibernate.engine.jdbc.dialect.internal.DialectFactoryImpl.determineDialect(DialectFactoryImpl.java:104) at org.hibernate.engine.jdbc.dialect.internal.DialectFactoryImpl.buildDialect(DialectFactoryImpl.java:71) at org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java:205) at org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java:111) at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:234) at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:206) at org.hibernate.cfg.Configuration.buildTypeRegistrations(Configuration.java:1887) at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1845) at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl$4.perform(EntityManagerFactoryBuilderImpl.java:857) at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl$4.perform(EntityManagerFactoryBuilderImpl.java:850) at org.hibernate.boot.registry.classloading.internal.ClassLoaderServiceImpl.withTccl(ClassLoaderServiceImpl.java:425) at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:849) at org.springframework.orm.jpa.vendor.SpringHibernateJpaPersistenceProvider.createContainerEntityManagerFactory(SpringHibernateJpaPersistenceProvider.java:60) at org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean.createNativeEntityManagerFactory(LocalContainerEntityManagerFactoryBean.java:343) at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.afterPropertiesSet(AbstractEntityManagerFactoryBean.java:318) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1637) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1574) ... 22 more

7 respostas

Fala aí Igor, beleza? Qual seria a versão do seu Java?

Fala Matheus. Tudo beleza! A versão do meu java é a 8, implementação da Oracle. Estou usando XUbuntu 18.04

Boa noite pessoal. Estou travado sem poder andar com o curso. Alguém da Alura poderia ajudar? Poderiam disponibilizar um JAR que não dê o erro mencionado? Obrigado.

Igor, você tem o MySQL instalado e configurado na sua máquina?

A aplicação foi feita e funciona corretamente no Java 7, no 8 já não sei se deve funcionar (acredito que não).

Outro detalhe, para que os alunos não fiquem travados devido a problema ao rodar a API, foi criado a mesma API porém hospedada no Heroku:

https://cdc-react.herokuapp.com/api/autores

Espero ter ajudado.

Olá Matheus. Obrigado pelo retorno.

Não tenho o mysql instalado. Deixo uma sugestão para vocês colocaram em algum os requisitos para a aplicação java =)

Vou tentar com a API online. Abraço.

Fala Igor, tem um exercício explicando como configurar o ambiente para rodar o back:

https://cursos.alura.com.br/course/react/task/19739

Espero ter ajudado.

E aí Igor, tudo bem?

Eu também estava com erro ao rodar o java -jar, mas consegui resolver permitindo que meu mysql seja acessado sem a necessidade do super-user. Lembrando que instalei o MySQL com o usuário root dele sem senha.

Caso queira tentar, fiz o seguinte:

  1. Acessei o MySQL como super-user: sudo mysql -u root -p
  2. Acessei a tabela mysql: use mysql;
  3. Fiz um update na tabela mysql atualizando a coluna plugin do usuário root para mysql_native_password: update user set plugin='mysql_native_password' where user='root' and host='localhost';
  4. Feito isso execute flush privileges;, deslogue-se do mysql e tente logar novamente com o usuário root e sem senha.

Depois disso consegui rodar o -jar normalmente e dar continuidade ao curso.