Is it possible that an IP is not allocated but the state is not Free ? The sql query below should return empty results.
select * from cloud.user_ip_address where removed is null and allocated is null and state !='Free'; -Wei On Thu, 16 Nov 2023 at 10:11, Daan Hoogland <daan.hoogl...@gmail.com> wrote: > strange Christian, > > I checked the code and the only thing I can think of is that creating > a DB lock fails. > > if (_ipAddressDao.lockRow(possibleAddr.getId(), true) != null) { > final IPAddressVO userIp = > _ipAddressDao.findById(possibleAddr.getId()); > if (userIp.getState() == State.Free) { > possibleAddr.setState(State.Allocating); > if (_ipAddressDao.update(possibleAddr.getId(), possibleAddr)) { > finalAddress = possibleAddr; > break; > } > } > } > > Unfortunately, no further logging can be turned on to investigate. > > is this a persistent error (i.e. remains after restarting system > components like the MS and the DB)? > > On Wed, Nov 15, 2023 at 5:52 PM <cristian.c@istream.today> wrote: > > > > > > Hello, > > > > > > > > Today, I tried to deploy new VMs, but I encountered the following error: > > failed to fetch any free public IP address. This is incorrect, as even on > > the dashboard, I can see 12/22 for Public and 172/212 for Shared. For > this > > deployment, I used the Shared/guest network. I also checked the database > and > > saw 41 free IPs for this zone. > > > > > > Any suggestions? > > > > > > 2023-11-15 11:18:53,441 INFO [c.c.h.v.m.VirtualMachineMO] > > (DirectAgent-19:ctx-a91068e2 usa-nyc-001.test.host, cmd: > > GetVolumeStatsCommand) (logid:851b339a) Look for disk device info from > > volume : ROOT-6215_2.vmdk with base name: ROOT-6215_2 > > > > 2023-11-15 11:18:53,441 INFO [c.c.h.v.m.VirtualMachineMO] > > (DirectAgent-19:ctx-a91068e2 usa-nyc-001.test.host, cmd: > > GetVolumeStatsCommand) (logid:851b339a) Test against disk device, > controller > > key: 1000, unit number: 0 > > > > 2023-11-15 11:18:53,441 INFO [c.c.h.v.m.VirtualMachineMO] > > (DirectAgent-19:ctx-a91068e2 usa-nyc-001.test.host, cmd: > > GetVolumeStatsCommand) (logid:851b339a) Test against disk backing : > [nyc001] > > i-2-6215-VMAMS/ROOT-6215_2.vmdk > > > > 2023-11-15 11:18:53,441 INFO [c.c.h.v.m.VirtualMachineMO] > > (DirectAgent-19:ctx-a91068e2 usa-nyc-001.test.host, cmd: > > GetVolumeStatsCommand) (logid:851b339a) Disk backing : [nyc001] > > i-2-6215-VMAMS/ROOT-6215_2.vmdk matches ==> scsi0:0 > > > > 2023-11-15 11:18:54,194 INFO [c.c.n.NetworkModelImpl] > > (qtp1444635922-323:ctx-a813b819 ctx-3b16875f) (logid:2b3f6d9b) Checking > > permission for account admin (17274c5e-d492-11e5-86c3-000c298715c8) on > > network TestHost-Public-NYC (1bece1dc-d9c1-4bff-b5aa-67333a6830ae) > > > > 2023-11-15 11:18:54,309 INFO [c.c.v.VirtualMachineManagerImpl] > > (qtp1444635922-323:ctx-a813b819 ctx-3b16875f) (logid:2b3f6d9b) allocating > > virtual machine from template:391d4eab-1506-44be-b743-5ae7bd0f4ad7 with > > hostname:i-2-6262-VMAMS and 1 networks > > > > 2023-11-15 11:18:54,325 ERROR [c.c.n.IpAddressManagerImpl] > > (qtp1444635922-323:ctx-a813b819 ctx-3b16875f) (logid:2b3f6d9b) Failed to > > fetch any free > > > > public IP address > > > > 2023-11-15 11:18:54,340 ERROR [c.c.a.ApiServer] > > (qtp1444635922-323:ctx-a813b819 ctx-3b16875f) (logid:2b3f6d9b) unhandled > > exception executing api command: [Ljava.lang.String;@4a8c9f6c > > > > com.cloud.utils.exception.CloudRuntimeException: Failed to fetch any free > > public IP address > > > > at > > > com.cloud.network.IpAddressManagerImpl.lambda$assignAndAllocateIpAddressEntr > > y$0(IpAddressManagerImpl.java:374) > > > > at com.cloud.utils.db.Transaction.execute(Transaction.java:40) > > > > at > > > com.cloud.network.IpAddressManagerImpl.assignAndAllocateIpAddressEntry(IpAdd > > ressManagerImpl.java:339) > > > > at > > > com.cloud.network.IpAddressManagerImpl.fetchNewPublicIp(IpAddressManagerImpl > > .java:821) > > > > at > > > com.cloud.network.IpAddressManagerImpl.fetchNewPublicIp(IpAddressManagerImpl > > .java:810) > > > > at > > > com.cloud.network.IpAddressManagerImpl.assignPublicIpAddress(IpAddressManage > > rImpl.java:778) > > > > at > > > com.cloud.network.IpAddressManagerImpl$10.doInTransactionWithoutResult(IpAdd > > ressManagerImpl.java:2240) > > > > at > > > com.cloud.utils.db.TransactionCallbackWithExceptionNoReturn.doInTransaction( > > TransactionCallbackWithExceptionNoReturn.java:25) > > > > at > > > com.cloud.utils.db.TransactionCallbackWithExceptionNoReturn.doInTransaction( > > TransactionCallbackWithExceptionNoReturn.java:21) > > > > at com.cloud.utils.db.Transaction.execute(Transaction.java:40) > > > > at > > > com.cloud.network.IpAddressManagerImpl.allocateDirectIp(IpAddressManagerImpl > > .java:2220) > > > > at > > > com.cloud.network.guru.DirectNetworkGuru$1.doInTransactionWithoutResult(Dire > > ctNetworkGuru.java:324) > > > > at > > > com.cloud.utils.db.TransactionCallbackWithExceptionNoReturn.doInTransaction( > > TransactionCallbackWithExceptionNoReturn.java:25) > > > > at > > > com.cloud.utils.db.TransactionCallbackWithExceptionNoReturn.doInTransaction( > > TransactionCallbackWithExceptionNoReturn.java:21) > > > > at com.cloud.utils.db.Transaction.execute(Transaction.java:40) > > > > at > > > com.cloud.network.guru.DirectNetworkGuru.allocateDirectIp(DirectNetworkGuru. > > java:317) > > > > at > > > com.cloud.network.guru.DirectNetworkGuru.allocate(DirectNetworkGuru.java:290 > > ) > > > > at > > > org.apache.cloudstack.engine.orchestration.NetworkOrchestrator.allocateNic(N > > etworkOrchestrator.java:1025) > > > > at > > > org.apache.cloudstack.engine.orchestration.NetworkOrchestrator.addRequestedN > > > icToNicListWithDeviceNumberAndRetrieveDefaultDevice(NetworkOrchestrator.java > > :877) > > > > at > > > org.apache.cloudstack.engine.orchestration.NetworkOrchestrator.allocate(Netw > > orkOrchestrator.java:850) > > > > at > > > com.cloud.vm.VirtualMachineManagerImpl.allocate(VirtualMachineManagerImpl.ja > > va:491) > > > > at > > > org.apache.cloudstack.engine.orchestration.CloudOrchestrator.createVirtualMa > > chine(CloudOrchestrator.java:255) > > > > at > > com.cloud.vm.UserVmManagerImpl.commitUserVm(UserVmManagerImpl.java:4527) > > > > at > > com.cloud.vm.UserVmManagerImpl.commitUserVm(UserVmManagerImpl.java:4630) > > > > at > > > com.cloud.vm.UserVmManagerImpl.getUncheckedUserVmResource(UserVmManagerImpl. > > java:4261) > > > > at > > > com.cloud.vm.UserVmManagerImpl.getCheckedUserVmResource(UserVmManagerImpl.ja > > va:3972) > > > > at > > > com.cloud.vm.UserVmManagerImpl.createVirtualMachine(UserVmManagerImpl.java:3 > > 955) > > > > at > > > com.cloud.vm.UserVmManagerImpl.createAdvancedVirtualMachine(UserVmManagerImp > > l.java:3729) > > > > at > > > com.cloud.vm.UserVmManagerImpl.createVirtualMachine(UserVmManagerImpl.java:5 > > 937) > > > > at > > java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native > > Method) > > > > at > > > java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodA > > ccessorImpl.java:62) > > > > at > > > java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(Delegatin > > gMethodAccessorImpl.java:43) > > > > at java.base/java.lang.reflect.Method.invoke(Method.java:566) > > > > at > > > org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopU > > tils.java:344) > > > > at > > > org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint > > (ReflectiveMethodInvocation.java:198) > > > > at > > > org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(Reflect > > iveMethodInvocation.java:163) > > > > at > > > org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(Expos > > eInvocationInterceptor.java:97) > > > > at > > > org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(Reflect > > iveMethodInvocation.java:186) > > > > at > > > org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopPro > > xy.java:215) > > > > at com.sun.proxy.$Proxy185.createVirtualMachine(Unknown Source) > > > > at > > > org.apache.cloudstack.api.command.user.vm.DeployVMCmd.create(DeployVMCmd.jav > > a:793) > > > > at > > > com.cloud.api.dispatch.CommandCreationWorker.handle(CommandCreationWorker.ja > > va:47) > > > > at > > com.cloud.api.dispatch.DispatchChain.dispatch(DispatchChain.java:37) > > > > at > > com.cloud.api.ApiDispatcher.dispatchCreateCmd(ApiDispatcher.java:88) > > > > at com.cloud.api.ApiServer.queueCommand(ApiServer.java:703) > > > > at com.cloud.api.ApiServer.handleRequest(ApiServer.java:603) > > > > at > > com.cloud.api.ApiServlet.processRequestInContext(ApiServlet.java:347) > > > > at com.cloud.api.ApiServlet$1.run(ApiServlet.java:154) > > > > at > > > org.apache.cloudstack.managed.context.impl.DefaultManagedContext$1.call(Defa > > ultManagedContext.java:55) > > > > at > > > org.apache.cloudstack.managed.context.impl.DefaultManagedContext.callWithCon > > text(DefaultManagedContext.java:102) > > > > at > > > org.apache.cloudstack.managed.context.impl.DefaultManagedContext.runWithCont > > ext(DefaultManagedContext.java:52) > > > > at com.cloud.api.ApiServlet.processRequest(ApiServlet.java:151) > > > > at com.cloud.api.ApiServlet.doGet(ApiServlet.java:105) > > > > at javax.servlet.http.HttpServlet.service(HttpServlet.java:645) > > > > at javax.servlet.http.HttpServlet.service(HttpServlet.java:750) > > > > at > > > org.eclipse.jetty.servlet.ServletHolder$NotAsync.service(ServletHolder.java: > > 1450) > > > > at > > org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:799) > > > > at > > > org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:554) > > > > at > > > org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143 > > ) > > > > at > > > org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:600) > > > > at > > > org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:1 > > 27) > > > > at > > > org.eclipse.jetty.server.handler.ScopedHandler.nextHandle(ScopedHandler.java > > :235) > > > > at > > > org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java > > :1624) > > > > at > > > org.eclipse.jetty.server.handler.ScopedHandler.nextHandle(ScopedHandler.java > > :233) > > > > at > > > org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java > > :1440) > > > > at > > > org.eclipse.jetty.server.handler.ScopedHandler.nextScope(ScopedHandler.java: > > 188) > > > > at > > org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:505) > > > > at > > > org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java: > > 1594) > > > > at > > > org.eclipse.jetty.server.handler.ScopedHandler.nextScope(ScopedHandler.java: > > 186) > > > > at > > > org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java: > > 1355) > > > > at > > > org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141 > > ) > > > > at > > > org.eclipse.jetty.server.handler.gzip.GzipHandler.handle(GzipHandler.java:77 > > 2) > > > > at > > > org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection. > > java:146) > > > > at > > > org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:1 > > 27) > > > > at org.eclipse.jetty.server.Server.handle(Server.java:516) > > > > at > > > org.eclipse.jetty.server.HttpChannel.lambda$handle$1(HttpChannel.java:487) > > > > at > > org.eclipse.jetty.server.HttpChannel.dispatch(HttpChannel.java:732) > > > > at > org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:479) > > > > at > > > org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:277) > > > > at > > org.eclipse.jetty.io > .AbstractConnection$ReadCallback.succeeded(AbstractConne > > ction.java:311) > > > > at org.eclipse.jetty.io > .FillInterest.fillable(FillInterest.java:105) > > > > at > > > org.eclipse.jetty.io.ssl.SslConnection$DecryptedEndPoint.onFillable(SslConne > > ction.java:555) > > > > at > > org.eclipse.jetty.io.ssl.SslConnection.onFillable(SslConnection.java:410) > > > > at > > > org.eclipse.jetty.io.ssl.SslConnection$2.succeeded(SslConnection.java:164) > > > > at org.eclipse.jetty.io > .FillInterest.fillable(FillInterest.java:105) > > > > at > > org.eclipse.jetty.io.ChannelEndPoint$1.run(ChannelEndPoint.java:104) > > > > at > > > org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.runTask(EatWhatYouKill > > .java:338) > > > > at > > > org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.doProduce(EatWhatYouKi > > ll.java:315) > > > > at > > > org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.tryProduce(EatWhatYouK > > ill.java:173) > > > > at > > > org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.run(EatWhatYouKill.jav > > a:131) > > > > at > > > org.eclipse.jetty.util.thread.ReservedThreadExecutor$ReservedThread.run(Rese > > rvedThreadExecutor.java:409) > > > > at > > > org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java: > > 883) > > > > at > > > org.eclipse.jetty.util.thread.QueuedThreadPool$Runner.run(QueuedThreadPool.j > > ava:1034) > > > > at java.base/java.lang.Thread.run(Thread.java:829) > > > > 2023-11-15 11:18:54,406 WARN [c.c.a.m.AgentManagerImpl] > > (AgentManager-Handler-1:null) (logid:) Throwing away a request because it > > came through as > > > > the first command on a connect: null > > > > > > > > Regards, > > > > Cristian > > > > > -- > Daan >